



IM Release # LLNL-TM-839227
ELM-U Release # 1016194982

Revision: 2.1.2

# Nanosecond Gated CMOS Camera (NSGCC) Interface Control Document (ICD)

## LLNL v1 Camera Board

| Anne Garafalo<br>hCMOS Project Manager |           |      |
|----------------------------------------|-----------|------|
|                                        | Signature | Date |
| Brad Funsten                           |           |      |
| Project FPGA Engineer                  |           |      |
|                                        | Signature | Date |
| Jeremy Martin Hill                     |           |      |
| Project Software Engineer              |           |      |
|                                        | Signature | Date |

| Rev.  | Date      | Section<br>Edits       | Eng.       | Description of Change                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.1.2 | 1/30/2025 | 5.5, 6,<br>11.1,<br>13 | BTF<br>JMH | nsCamera software release 2.1.2 Renamed L/R hemisphere registers, subregisters, signals to A/B Added subregisters to HST_PHI_DELAY_DATA_LO Removed Daedalus content from V1 ICD Changed HST_RO_IBIAS and HST_RO_NC_IBIAS for both pot 4 and 12 respectively to state that voltage is proportional to the frequency of the respective ring oscillators. Updated IM Release number Updated Manual Shutter Control to state that manual timing for the hemispheres can be programmed independently. Added reference to the jupyter notebook file in the nsCamera software package for how to use manual shutters. Added Image Capture Definitions section. Added sentence discussing self-clearing. Made registers that are self-clearing consistent to reader. Updated title of cover page. Removed dual-edge trigger functionality Added subregister chart for Trigger Control scheme |
| 2.1   | 7/6/2021  | -                      | JMH        | nsCamera software release 2.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.02  | 1/8/2021  | 11.1                   | BTF        | Added five more bits to MISC_SENSOR_CTL register for accumulation mode control and reordered the register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2.01  | 11/3/2020 | 11.1                   | BTF        | Added MISC_SENSOR_CTL register to control miscellaneous Icarus sensor pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Previous change notes may be found in Section 17





#### Disclaimer

This document was prepared as an account of work sponsored by an agency of the United States government. Neither the United States government nor Lawrence Livermore National Security, LLC, nor any of their employees makes any warranty, expressed or implied, or assumes any legal liability or responsibility for the accuracy, completeness, or usefulness of any information, apparatus, product, or process disclosed, or represents that its use would not infringe privately owned rights. Reference herein to any specific commercial product, process, or service by trade name, trademark, manufacturer, or otherwise does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States government or Lawrence Livermore National Security, LLC. The views and opinions of authors expressed herein do not necessarily state or reflect those of the United States government or Lawrence Livermore National Security, LLC, and shall not be used for advertising or product endorsement purposes. This work performed under the auspices of the U.S. Department of Energy by Lawrence Livermore National Laboratory under Contract DE-AC52-07NA2734.

### Contents

| C | onte | ents                           | 2    |
|---|------|--------------------------------|------|
| 1 | В    | Background                     | 3    |
| 2 |      | Design Summary                 | 4    |
| 3 | Е    | Block Diagram                  | 6    |
| 4 | H    | Host Communications Interfaces | 7    |
|   | 4.1  | Communications Port Selection  | 7    |
| 5 | S    | Sensor Interface               | 7    |
|   | 5.1  | ADC Interface and Control      | 7    |
|   | 5.2  | SRAM Interface and Control     | 9    |
|   | 5.3  | Automatic Sensor Detection     | 9    |
|   | 5.4  | Sensor Power Control           | 9    |
|   | 5.5  | Image Capture Definitions      | 9    |
| 6 | T    | Trigger Control                | . 10 |
|   | 6.1  | Hardware Triggers              | . 10 |
|   | 6.2  | Software Triggers              | . 10 |
| 7 |      | Digital Potentiometers         | . 11 |
| 8 | T    | Temperature Sensor             | . 11 |
| 9 | P    | Packet Formats                 | . 11 |
|   | 9.1  | Command Packet                 | . 12 |
|   | 9.2  | Response Packet                | . 12 |
|   | 9.3  | Burst Response Packet          | . 13 |
| 1 | 0 I  | nstructions                    | . 13 |
| 1 | 1 F  | Registers                      | . 14 |
|   | 11.  | 1 Register Map                 | . 15 |
| 1 | 2 E  | Error Recovery and Diagnostics | . 28 |
|   | 12.  | 1 Software Reset               | . 28 |
|   | 12.  |                                |      |
|   | 12.  |                                |      |
|   | 12.  | 4 FPA Interface Module Timeout | . 29 |
|   |      |                                |      |





| 1  | 2.5   | SRAM Readoff Module Timeout           | 29 |
|----|-------|---------------------------------------|----|
| 1  | 2.6   | Read Burst Processing Module Timeouts | 29 |
| 1  | 2.7   | Resets                                | 30 |
| 13 | Icaru | us implementation                     | 31 |
| 1  | 3.1   | ADC Interface and Control             | 31 |
| 1  | 3.2   | ADC-Potentiometer Mapping             | 32 |
| 1  | 3.3   | Anti-Bloom Circuit Control            | 33 |
| 1  | 3.4   | Sensor Power Control                  | 33 |
| 1  | 3.5   | High-Speed Timing (HST) Control       | 33 |
| 1  | 3.6   | Manual Shutter Control                | 34 |
| 1  | 3.7   | Power Save Mode                       |    |
| 14 | RS42  | 22 USB Cable                          | 35 |
| 15 | Soft  | ware Support                          | 35 |
| 16 | ELM   | -U References                         | 35 |
| 17 | Char  | nge note history                      | 36 |
| 18 | Refe  | erences                               | 37 |
|    |       |                                       |    |

## 1 Background

The Ultra-Fast X-ray Imager (UXI) program is an ongoing effort at Sandia National Laboratories to create high speed, multi-frame, time-gated Read Out Integrated Circuits (ROICs), and a corresponding suite of photodetectors to image a wide variety of High Energy Density (HED) physics experiments on both Sandia's Z-Machine and LLNL's National Ignition Facility (NIF). Several cameras have been designed over the length of the program; one of the most recent is the Icarus, which is an improvement on past imagers (Furi and Hippogriff). The Icarus is a  $1024 \times 512$ -pixel array with 25  $\mu$ m spatial resolution containing four frames of storage per pixel and has improved timing generation and distribution components while achieving 2 ns time gating. The Daedalus sensor is also a  $1024 \times 512$ -pixel array with 25  $\mu$ m special resolution containing three frames of storage per pixel and has an expanded set of features for a wider variety of applications from interlacing of rows in each frame to configurability of all shutters. <sup>1</sup> See Section 13 for details regarding the Icarus implementation of the firmware; Daedalus is no longer supported on the LLNL V1.0 board as of May 2022.

Due to the unique test environments UXI sensors are targeted for, full custom hardware was required to physically mount the Icarus, manage its various functions, and read out pixel data for transfer to a host computer. Beyond experimental functionality, the hardware also needed to accommodate sensor characterization requirements. Lawrence Livermore National Laboratory's 'Version 1.0 Board' was the result of these efforts. It mounts all the components required to fully utilize the Icarus including analog to digital converters to convert pixel data and various system voltages to digital form for readout and analysis, digital potentiometers for remote configuration of critical bias voltages, static random-access memories to buffer pixel data, RS422 and Gigabit Ethernet communications for remote access, and an FPGA to tie these components together. This document describes the FPGA electrical interfaces in detail

<sup>&</sup>lt;sup>1</sup> This paragraph was sourced from References 2, 4, 5, and 6.





to allow the reader a greater understanding of the device, and to facilitate implementation of custom software to control and manage it.

## 2 Design Summary

The Nanosecond Gated CMOS Camera (NSGCC) FPGA is a design targeted for the Microsemi A3PE3000-FG484 device residing on the LLNL Version 1.0 Board. It controls interaction between a host computer and the functions on the board, whose major components include an image sensor mounted on a daughter board, SRAM, analog to digital converters (ADCs), digital potentiometers (POTs), temperature sensors, and power circuitry.

|          |                        | Readoff Time           |                  |  |
|----------|------------------------|------------------------|------------------|--|
| Port     | ICARUS 2-Frame Readout | ICARUS 4-Frame Readout | Daedalus 3-Frame |  |
|          |                        |                        | Readout          |  |
| RS-422   | ~ 27 seconds           | ~ 54 seconds           | ~38 seconds      |  |
| Gigabit  | < 1 second             | 4.1 sacond             | 4.1 second       |  |
| Ethernet | < 1 Second             | < 1 second             | < 1 second       |  |

Table 1: Readoff time - Start of sensor readoff to images downloaded by host (approximate, does not include software overhead)

A summary of the feature set of the FPGA:

- RS422 and Gigabit Ethernet Ports for complete control of FPGA and sensor
- ARM/Disarm function which aggregates critical system status into one status bit
- Controls four NoBL (QDR) 72 Mbits SRAMs and four 8-channel ADCs for digitizing, buffering, and read out of pixel data to a host computer
- Utilizes thirteen digital POTs and one 8-channel ADC for calibration, monitoring, and tuning of critical bias voltages
- 10 kHz Heartbeat clock on Trigger3 BNC
- Timer/Counter which increments at 1 second intervals while FPGA is running
- Temperature sensor to monitor the system temperature
- Radiation-tolerant logic
- Supports the board's sensor voltage protection circuitry and enables image sensor power only
  when the correct sensor is installed, and the connected power supply provides the proper voltage.
- Power Supply requirement is 8 Volts at 2 Amps. The maximum current limit is 2.5 A.





A preliminary block diagram of the Version 1.0 Board, including the FPGA, is shown in Figure 1. The image sensor attaches to the Version 1.0 Board via a SamTec SEAF connector.



Figure 1: Version 1.0 Board, System Block Diagram





## 3 Block Diagram

A block diagram of the FPGA internal architecture is shown in Figure 2.



Figure 2: FPGA Block Diagram





### 4 Host Communications Interfaces

The NSGCC FPGA contains support for two serial interfaces for connectivity to a remote host computer—RS422 via a DB-9 connector, and Gigabit Ethernet via an RJ-45 connector. Only one port can be active at a time.

The RS422 port has a fixed configuration of 921.6 kbaud, 8 data bits, 0 parity bits, 1 stop bit; these settings cannot be modified by the user. The Gigabit Ethernet port can be accessed by connecting a standard Gigabit Ethernet adapter via a Cat 5a or better cable.

### 4.1 Communications Port Selection

Selection of the active communications port is performed through configuration pins on the FPGA (called *comm\_port\_sel\_i*[1:0]). Table 2 illustrates communications port selection.

| com_port_sel_i (i                   | Port<br>Selected |               |                     |
|-------------------------------------|------------------|---------------|---------------------|
| comm_port_sel_i[1:0]<br>logic level | JMP1 position    | JMP2 position |                     |
| 00                                  | 2-3              | 2-3           | RS422               |
| 01                                  | 2-3              | 1-2           | N/A                 |
| 10                                  | 1-2              | 2-3           | Gigabit<br>Ethernet |
| 11                                  | 1-2              | 1-2           | Reserved            |

Table 2: Communications Port Selection through FPGA Input Pins

## 5 Sensor Interface

The NSGCC FPGA controls the configuration and readout of the sensor in timing coordination with ADC conversion and SRAM storage. These functions are implemented with state machines, control logic, and command/status registers that respond to commands received from the host computer. ADC and SRAM functions will be discussed in the following sections: consult the associated sensor-specific ICD for relevant details. The hCMOS sensors, Icarus and Daedalus, consist of two hemispheres that can be independently controlled. The hemispheres are labeled A and B; alternatively, they may be referred to as the left and right hemispheres, respectively. *Warning*: physical 'left' and 'right' will depend upon the deployed orientation of the sensor.

### 5.1 ADC Interface and Control

The FPGA controls the five analog-to-digital converters (ADCs) on the board. All five ADCs are Texas Instruments ADS8568SPM, which are eight-channel 16-bit devices. Four of the ADCs are used to convert the image sensor's analog pixel information into 16-bit digital data. The fifth ADC (ADC5) is used to monitor a subset of the board's potentiometers (POTs). See Section 13.2 for the mapping of ADC5 inputs.

The FPGA reads the ADC5 periodically and writes the voltage data into the ADC5\_DATA\_1 through ADC5\_DATA\_4 registers; these can be read by the user at any time. The time between updates of these registers is controlled by the ADC5\_PPER register.

By populating and de-populating surface-mount selection resistors, the user can change the connectivity of three of ADC5's channels, numbers 3, 5, and 7. Channels 3 and 5 can be connected to external signals via J32, and channel 7 can be connected to VRST. The schematic snippet in Figure 3 illustrates the resistors that need to be populated/de-populated, and the connectivity to J32.

Prior to use, the host software must configure the ADCs properly using the ADC\_CTL and ADCX\_CONFIG\_DATA registers (see Section 11.1). First, the appropriate ADCX\_CONFIG\_DATA register(s)





must be configured (see the ADS8568SPM data sheet for configuration information). Then the **ADC\_CTL** register must be written to force the FPGA to write the configuration data to the targeted ADC(s).



Figure 3: ADC5 – Illustration of Channel 3, 5, and 7 Connectivity Options





### 5.2 SRAM Interface and Control

Each of the image sensor ADCs presents its output to the SRAM one channel at a time such that 4×16-bits, or 64 bits of data must be buffered simultaneously and continuously until all requested data is read from the sensor and stored in the SRAM. To handle storage of this data, the Version 1.0 Board contains two Cypress CY7C1470BV33-167AXI 2Mbit×36 SRAMs. When all pixel data has been stored, the FPGA asserts a status bit (STAT\_REG\_SRC bit 0, or SRAM\_READY). Software waits for this bit to go high to commence readout of pixel data from SRAM to the host for storage and processing.

### 5.3 Automatic Sensor Detection

POT11 assists in the automatic sensor detection process, where the attached sensor type is detected upon power on or reset, and the appropriate FPGA functions are configured to support the detected sensor. At system power on or reset, the FPGA will automatically program POT11 to 3.3 V for 2 seconds, then program it back to its default voltage. While at 3.3 V, the sensor\_det\_i signals from the sensor are biased such that they can be sampled by the FPGA to determine the sensor type that is attached. The FPGA will then assert bits in the SENSOR\_VOLT\_STAT status register indicating which sensor has been detected (see Table 3).

| Sensor Detect ( | FPGA input pins) | FPGA Control Bits (in SENSOR_VOLT_STAT register) |          |  |
|-----------------|------------------|--------------------------------------------------|----------|--|
| sensor_det(1)   | sensor_det(0)    | icarus_det                                       | reserved |  |
| 1               | 1                | 1                                                | 0        |  |
| 0               | 1                | 0                                                | 1        |  |
| 0               | 0                | 0                                                | 0        |  |
| 1               | 0                | N/A                                              | N/A      |  |

Table 3: Sensor Detect (sensor\_det) Truth Table

### 5.4 Sensor Power Control

Sensor power can be enabled by either the FPGA under software control, or by PCB-installed hardware circuitry. In Table 4, <code>bypass\_sensor\_det</code> is a bit in the <code>SENSOR\_VOLT\_CTL</code> register, <code>icarus\_det</code> is a bit in the <code>SENSOR\_VOLT\_STAT</code> register that is generated by the state of the sensor\_det[1:0] pins, and <code>pos\_n</code>, and <code>neg\_p</code> are signals from PCB circuitry. The last column, <code>Sensor\_power\_on</code>, is an output signal of the FPGA; when asserted, power to the sensor is turned on.

When *bypass\_sensor\_det* is low (logic 0), sensor power is dependent only on the state of *icarus\_det*, *pos\_n*, and *neg\_n*. When it is high (logic 1), sensor power is enabled independent of any other signal.

| bypass_<br>sensor_<br>det | lcarus_det | Pos_not | Neg_p | Sensor_<br>power_<br>on |
|---------------------------|------------|---------|-------|-------------------------|
| 0                         | 1          | 0       | 0     | 1                       |
| 0                         | 0          | 1       | 1     | 1                       |
| 1                         | Х          | Х       | Х     | 1                       |

Table 4: Sensor Power Enable Truth Table

## 5.5 Image Capture Definitions

There are image capture terms between the FPGA and sensor. Metal-Insulator-Metal (MIM) capacitor is the hCMOS sensor's capacitors that store the pixel charge. The number of capacitors is associated with the number of frames. The Icarus, with four frames, requires four MIM capacitors. The terms are as follows:





**Sensor Image Capture**: Arm and Trigger event, enables the shutters and stores voltages in the MIM capacitors.

**Pixel Readout**: The hCOMS sensor's MIM capacitor voltages are converted to digital data which is then stored in the camera's SRAM. This can occur sequentially after image capture by using triggers or using dedicated methods in firmware and software to perform pixel readout even when image capture has not occurred.

**SRAM Readout**: The digital data stored in the SRAM is transmitted via RS422 or GigE to the host computer. Can be triggered "manually" in software, possibly bypassing Image Capture and Pixel Readout.

## 6 Trigger Control

Two triggers are required to initiate image capture and retrieve images from the board--a Coarse Trigger, followed by a Fine Trigger. These triggers can be provided to the board through hardware (externally) or software (internally).

| Subregister | Hardware<br>Trigger | Software<br>Trigger |
|-------------|---------------------|---------------------|
| HW_TRIG_EN  | 1                   | 0                   |
| SW_TRIG_EN  | 0                   | 1                   |

Table 5: Subregister settings for trigger control

### 6.1 Hardware Triggers

The default trigger mode requires the use of external equipment to provide hardware triggers. The hardware trigger requirements are:

- Hardware triggers are enabled by asserting the HW\_TRIG\_EN subregister while deasserting SW\_TRIG\_EN (i.e., setting bit 0 of TRIGGER\_CTL while clearing bit2.)
- Both triggers must adhere to TTL logic levels as measured on the board
- Both triggers must have a minimum 200 ns pulse width as measured on the board
- For Icarus sensor operation, a minimum of 11.5 μs is needed between the rising edge of the Coarse Trigger and the rising edge of the Fine Trigger to obtain a successful edge detect (w0\_top\_l\_edge1) assertion after the assertion of the Fine Trigger. Please see the 'UXI\_Icarus\_FPA' document for more details regarding the edge detect signal from the Icarus sensor.<sup>5</sup>
- The signal source must be able to drive a 50  $\Omega$  load since both triggers are terminated on the board.

## 6.2 Software Triggers

The Software Triggers are generated internally to the FPGA and exceed the requirements for the Hardware Triggers— the pulse width of both triggers is 10 µs; and the rising edges occur 20 µs apart.

The software trigger is enabled by asserting the **SW\_TRIG\_EN** subregister while deasserting **HW\_TRIG\_EN** (clearing bit 0 of **TRIGGER\_CTL** while setting bit 2.) When subregister **SW\_TRIG\_START** is asserted, the software control logic will activate and assert first the Coarse Trigger then the Fine Trigger as described in the previous paragraph. **SW\_TRIG\_START** is self-clearing, so software does not need to clear it to disable this function.





Note that inside the FPGA, the hardware and software triggers are logically ORed together. Therefore, when the Software Trigger function is used, the user must not assert the Hardware Triggers.

## 7 Digital Potentiometers

There are thirteen digital potentiometers (POTs) on the board available to bias miscellaneous image sensor functions. Each of these devices is an Analog Devices AD5161; configuration is performed via the POT data registers (POT\_REG4\_TO\_1, POT\_REG8\_TO\_5, POT\_REG12\_TO\_9, and POT\_REG13), and the POT control register (POT\_CTL). To ensure that the POTs are programmed to valid values immediately upon turning on system power, the FPGA will detect the de-assertion of the system reset signal, and after a 1 ms delay will automatically program all POTs to the default values contained in their respective POT data registers. See Section 13.1 for the Icarus POT assignments.

When the user writes to the **POT\_CTL** register, a POT write command is initiated. It takes some time for the command to be generated, serialized, sent to the POT, and for the POT interface module to then terminate the process. If a POT write is initiated whilst a previous POT write is in progress, the second POT write will neither be executed nor buffered; it will be lost. This is not an issue when using the RS422 interface due to the slow communications rate but is potentially a problem when using the Gigabit Ethernet interface. Interface software must not execute a DAC write command for at least 50 µs following a previous DAC write command when the Gigabit Ethernet interface is used.

There is a similar delay required due to the special Anti-Bloom function associated with **POT11**. Since it takes some time for the Anti-Bloom function to execute (see Section 5.3), the interface software must not execute a POT write command for at least  $50 \mu s$  following a power cycle or a board reset.

## 8 Temperature Sensor

A TI275 temperature sensor is used to monitor sensor temperature; it is placed on the board adjacent to the sensor connector and provides ±0.5 °C accuracy. After the system is powered on, the FPGA will continually read the TI275 at an interval determined by the **TEMP\_SENSE\_PPER** register; the temperature is stored in the **TEMP\_SENS\_DATA** register, where it can be read by software using the Read Single command.

The value programmed into the **TEMP\_SENSE\_PPER** register represents the number of system clock cycles between the end of one TI275 temperature read cycle and the beginning of the next. Therefore, the TI275 read frequency is a function of **TEMP\_SENSE\_PPER** and the time it takes to read off the TI275. The frequency at which the TI275 is read (and the **TEMP\_SENS\_DATA** register is updated), use the following formula:

$$f_{\text{read}} = \frac{f_{\text{system\_clock}}}{(n_{\text{read}} + TSP)}$$

where  $n_{\rm read}$  is the number of clock cycles to read the TI275 = 2917,  $f_{\rm system\_clock} = 40,000,000$ , and TSP is the contents of the **TEMP\_SENSE\_PPER** register.

### 9 Packet Formats

The NSGCC FPGA supports three packet types: Command, Response, and Burst Response (i.e., pixel) Packets. Their formats and usage are described in this section.





### 9.1 Command Packet

A Command Packet is sent by the host to the FPGA; it may not be sent by the FPGA. A Command Packet is used to send an instruction to the FPGA for execution. All Command Packets shall have the format shown in Table 6.

| 16 bits  | 4 bits  | 12 bits | 32 bits | 16 bits |
|----------|---------|---------|---------|---------|
| Preamble | Command | Address | Data    | CRC16   |

Table 6: Command Packet Format

| Preamble | Bit pattern that precedes actual packet data to assist the receiver in determining the start of the packet. The preamble is fixed to 0xAAAA                                                                   |  |  |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Command  | 0x0: Write Single 0x1: Read Single 0x2: Read Burst (i.e., Read Pixels) All other values not supported                                                                                                         |  |  |  |  |
| Address  | Bit[11:0]: Defines the address of the target register of a Write Single or Read Single command. For a Read Burst command, this field is not used, but is recommended that it be filled with zeros.            |  |  |  |  |
| Data     | Bit[31:0]: Contains write data for a Write Single command. This field is not used for Read Single or Read Burst commands, but it is recommended that it be filled with zeros.                                 |  |  |  |  |
| CRC16    | Bit[15:0]: CRC-16 field, calculated over the entire packet, excluding the preamble and CRC field itself. The CRC16 field exists for RS422 packets only; for Ethernet packets, the CRC16 field does not exist. |  |  |  |  |

Table 7: Command Packet Fields

### 9.2 Response Packet

A response packet is sent by the FPGA to the host; it may not be sent by the host. Response Packets are sent either (1) in response to a Write Single packet where the response packets are not disabled, or (2) in response to a Read Single packet.

The Response Packet format is similar to the Command Packet format; this enables host software to easily correlate a Response Packet to the Command Packet that was the cause of its generation. However, there are a couple of minor differences, such as asserting the MSB of the Command field, and the content of the Data field.

| 16 bits  | 4 bits  | 12 bits | 32 bits | 16 bits |
|----------|---------|---------|---------|---------|
| Preamble | Command | Address | Status  | CRC16   |

Table 8: Response Packet Format

| Preamble | Bit pattern that precedes actual packet data to assist the receiver in determining the start of the packet. The preamble is fixed to 0xAAAA                                                                                                                                                                   |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command  | Contains the contents of the command field of the corresponding Command Packet, except that the MSB is asserted.  0x8: Write Single  0x9: Read Single  0xA: Read Burst (i.e., Read Pixels)                                                                                                                    |
| Address  | Same as the source Command Packet                                                                                                                                                                                                                                                                             |
| Status   | For Read Single Commands: This field contains the data read from the target register.  For Write Single Commands: This field contains status information, particularly errors, contained in the transmitted command packet. This status information does NOT refer to the response packet.  Bit[0]: CRC error |





|       | Bit[1]: Invalid Command – command not executed Bit[2]: Invalid Sub-Command – command not executed                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRC16 | Bit[15:0]: CRC-16 field, calculated over the entire packet, excluding the preamble and CRC field itself. The CRC16 field exists for RS422 packets only; for Ethernet packets, the CRC16 field does not |
| CRC16 | exist.                                                                                                                                                                                                 |

Table 9: Response Packet Fields

### 9.3 Burst Response Packet

Burst Response (or Pixel) Packets are sent in response to a Read Burst (or Read Pixels) command.

| 16 bits  | 4 bits  | 12 bits  | 32 bits        | Variable | 16 bits |
|----------|---------|----------|----------------|----------|---------|
| Preamble | Command | Reserved | Payload Length | Payload  | CRC16   |

Table 10: Burst Response Packet Format

| Preamble | Bit pattern that precedes actual packet data to assist the receiver in determining the start of the packet. The preamble is fixed to 0xAAAA                            |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command  | Contains the Command field of the Command Packet, except that the MSB is asserted.  OxA: Read Burst (i.e. Read Pixels)                                                 |
| Reserved | Field is not used, should be set to 0x000                                                                                                                              |
| Payload  | Length of the Payload field, in bytes. This is the total number of bytes transmitted for a particular                                                                  |
| Length   | SRAM readout.                                                                                                                                                          |
| Payload  | Payload. This field contains pixel data. Each pixel occupies 16-bits of payload; if the actual pixel data is less than 16 bits, the pixel data shall be zero-justified |
| CRC16    | CRC-16 field, calculated over the entire packet, excluding the preamble and CRC field itself. The                                                                      |
| CKCIO    | CRC16 field exists for RS422 packets only; for Ethernet packets, the CRC16 field does not exist.                                                                       |

Table 11: Burst Response Fields

### 10 Instructions

Three instructions are currently supported: Write Single, Read Single, and Read Burst.

The Write Single instruction is used by the host to update and modify the NSGCC FPGA's control registers. By writing to the appropriate control registers in the correct sequence, the host can control all NSGCC FPGA and Version 1.0 Board functions. When the FPGA receives a command packet with a Write Single instruction with response packets enabled, it will return a response packet indicating reception of the packet and whether it was received error-free.

The Read Single instruction is used to read the content of a single NSGCC control or status register. This instruction enables the host to determine the status of all FPGA functions that are supported. When a command packet with a Read Single instruction is received by the FPGA, it *must* return a response packet, which contains the FPGA target register contents. Again, it is up to the host to determine a suitable timeout period while awaiting the response packet and to re-send the packet if required.

The Read Burst instruction is used to read sensor data from the Version 1.0 Board's SRAM; it should be sent by the host only after pixel data is read from the ADC and stored in SRAM. When this instruction is received by the FPGA via a command packet, it will return a single of Burst Response packets with the format described in the previous section.





## 11 Registers

This section lists all NSGCC FPGA registers accessible by the software. All registers are 32 bits wide, although not all bits are used in every register. Registers or individual bits of registers may be self-clearing; that is, the firmware will ingest any bits set then automatically clear them. The different register types are defined as follows:

- Read Only: Software can read the register but cannot modify its contents. The register's contents are updated/modified only by internal FPGA hardware.
- Read/Write: Software can read or write the register; hardware cannot update/modify the register contents, unless stated.
- Self-Clearing: Software can read the register; the register's contents are cleared (i.e., reset to
  zeros) when read by software. However, if software has not resolved the underlying cause of
  asserted status bits, reading this type of register may not result in all zeros being read from it. A
  typical example is an interrupt register, when the underlying source of the interrupt has not been
  cleared.







## 11.1 Register Map

| Address                  | Register Name            |              |                                                      |                                                     | Board        | Access                                   | Default value |  |  |
|--------------------------|--------------------------|--------------|------------------------------------------------------|-----------------------------------------------------|--------------|------------------------------------------|---------------|--|--|
| Register de              | escription               | Bit<br>range | Details                                              | Details of bit range (may include SUBREGISTER_NAME) |              |                                          |               |  |  |
| 0x000                    | FPGA_NUM                 |              |                                                      |                                                     | V1, V4       |                                          | 0x8100_0301   |  |  |
|                          |                          |              | Board o                                              | developer                                           |              |                                          | 1             |  |  |
|                          |                          | 31           | 0                                                    | SNL                                                 |              |                                          |               |  |  |
|                          |                          |              | 1                                                    | LLNL                                                |              |                                          |               |  |  |
|                          |                          | 30:28        | Unused                                               | 1                                                   |              |                                          |               |  |  |
| Product Nu               | umber of the FPGA design |              |                                                      | major revision number                               | r            |                                          |               |  |  |
|                          | acter sequence:          | 27:24        | 0001                                                 | 0001 LLNLv1                                         |              |                                          |               |  |  |
| _                        | ard developer            |              |                                                      | 0100 LLNLv4                                         |              |                                          |               |  |  |
| 2: Board revision number |                          | 23:10        | Unused                                               |                                                     |              |                                          |               |  |  |
| 3-5: ur                  |                          | 9            | '1' indicates Gigabit Ethernet interface implemented |                                                     |              |                                          |               |  |  |
| 6: Con                   | nmunication interfaces   | 8            | '1' indicates RS422 interface implemented            |                                                     |              |                                          |               |  |  |
| 7: Rad                   | liation tolerance        | 7:5          | Unused                                               | -                                                   |              |                                          |               |  |  |
| 8: Sen                   | sor build                | 4            |                                                      |                                                     | ates optimi  | zed radiation-tolerant implementation    |               |  |  |
|                          |                          |              |                                                      | implementation                                      |              |                                          |               |  |  |
|                          |                          |              | 0000 Undefined                                       |                                                     |              |                                          |               |  |  |
|                          |                          | 3:0          | 0001                                                 | Icarus / Icarus 2                                   |              |                                          |               |  |  |
|                          |                          |              | 0010                                                 | Daedalus (Unused)                                   |              |                                          |               |  |  |
|                          |                          |              | 0011                                                 | Reserved                                            |              |                                          |               |  |  |
| 0x001                    | FPGA_REV                 |              |                                                      |                                                     | V1, V4       | Read-only                                |               |  |  |
|                          |                          | 7:0          | Day of                                               | FPGA code release (e.                               | g., 0x29 fo  | r the 29 <sup>th</sup> day of the month) |               |  |  |
|                          |                          | 15:8         | Month                                                | of FPGA code release                                | (e.g., 0x12  | for the month of December)               |               |  |  |
| Revision of              | f FPGA design.           | 23:16        | Year of                                              | FPGA code release (e                                | .g., 0x18 fo | or the year 2018)                        |               |  |  |
|                          |                          | 27:24        | Unused                                               | i                                                   |              |                                          |               |  |  |
|                          |                          | 31:28        | Board v                                              | version (e.g., 0x1 for v                            | 1 board)     |                                          |               |  |  |







| 0x010                   | HS_TIMING_CTL                            |      |                                                      |                                                     | V1, V4             | Read/Write, self-clearing                                                               | 0×0000_0000              |  |
|-------------------------|------------------------------------------|------|------------------------------------------------------|-----------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------|--------------------------|--|
| Control o               | f HS Timing Function                     | 0    | 1                                                    | <b>ODE</b> - Configure timing to the FPA interface. |                    | is self-clearing. When '1', HST configur                                                | ration is initiated with |  |
| 0x013                   | HS_TIMING_DATA_ALO                       |      |                                                      |                                                     | V1, V4             | Read/Write                                                                              | 0x0000_0000              |  |
| Custom h                | igh-speed timing A side, LSBs            | 31:0 | Timing                                               | pattern bits [31:0] for                             | A side             |                                                                                         |                          |  |
| 0x014                   | HS_TIMING_DATA_AHI                       |      |                                                      |                                                     | V1, V4             | Read/Write                                                                              | 0x0000_0000              |  |
| Custom h                | igh-speed timing A side, MSBs            | 7:0  | Timing                                               | pattern bits [39:32] fo                             | or A side          |                                                                                         |                          |  |
| 0x015                   | HS_TIMING_DATA_BLO                       |      |                                                      |                                                     | V1, V4             | Read/Write                                                                              | 0x0000_0000              |  |
| Custom h                | igh-speed timing B side, LSBs            | 31:0 | Timing                                               | pattern bits [31:0] for                             | B side             |                                                                                         |                          |  |
| 0x016                   | HS_TIMING_DATA_BHI                       |      |                                                      |                                                     | V1, V4             | Read/Write                                                                              | 0x0000_0000              |  |
| Custom h                | igh-speed timing B side, MSBs            | 7:0  | Timing                                               | pattern bits [39:32] fo                             | or B side          |                                                                                         |                          |  |
| 0x017                   | SW_TRIGGER_CONTROL                       |      |                                                      |                                                     | V1, V4             | Write, self-clearing                                                                    |                          |  |
| Initiates g<br>triggers | generation of internal coarse and fine   | 0    | coarse                                               | _                                                   | 0 μs, then 1       | '1', initiates coarse and fine triggers i<br>11.5 μs after the coarse trigger goes high |                          |  |
| 0x024                   | STAT_REG                                 |      |                                                      |                                                     | V1, V4             | Read-only                                                                               |                          |  |
| Status Re<br>(Read-onl  | gister.<br>ly duplicate of STAT_REG_SRC) | 31:0 | 1                                                    |                                                     |                    | RC (0x02F). Reading this register has in T_REG_ SRC must be read. See 0x02F for         |                          |  |
| 0x025                   | CTRL_REG                                 |      |                                                      |                                                     | V1, V4             | Read/Write                                                                              | 0x0000_0002              |  |
|                         |                                          | 0    | Unused                                               | I                                                   |                    |                                                                                         | 1                        |  |
|                         |                                          | 1    | LED_EN – Enable user-managed LEDs                    |                                                     |                    |                                                                                         |                          |  |
|                         |                                          | 2    |                                                      |                                                     |                    | le. When '1', enables column quench fu                                                  |                          |  |
| Control R               | egister                                  |      | -                                                    | 1                                                   |                    | rols the assertion of <i>HST_osc_bias_en</i> to                                         | save power.              |  |
|                         |                                          | 3    | 0                                                    | HST_osc_bias_en is                                  |                    |                                                                                         | un LICT and bing are in  |  |
|                         |                                          |      | 1                                                    | deasserted when se                                  |                    | pon the rising edge of the Coarse Trigge<br>ut begins                                   | er; mo i_osc_bias_en is  |  |
|                         |                                          |      | REVREAD - When '1', reverses the frame readout order |                                                     |                    |                                                                                         |                          |  |
|                         |                                          | 4    | REVRE                                                | AD - When '1', reverse                              | es the frame       | e readout order                                                                         |                          |  |
| 0x026                   | POT_CTL                                  | 4    | REVRE                                                | AD - When '1', reverse                              | es the frame<br>V1 | e readout order<br>Read/Write                                                           | 0x0000_0000              |  |







| Dot config                                                                      | uration control for specific channels                        | 0     | POT_CONFIG. When written in its corresponding register.       |                                                                                                                                                                                                                       | he POT selected by POT_SEL will be configuelf-clearing.                               | ired with the value |  |  |
|---------------------------------------------------------------------------------|--------------------------------------------------------------|-------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------|--|--|
| Pot configuration control for specific channels —                               |                                                              |       |                                                               |                                                                                                                                                                                                                       | r to configure. Selection is literal, i.e.:<br>POT2 "1101" = select POT13             |                     |  |  |
| 0x027                                                                           | POT_REG4_TO_1                                                |       |                                                               | V1                                                                                                                                                                                                                    | Read/Write                                                                            |                     |  |  |
|                                                                                 |                                                              | 7:0   | POT1 / COL_BOT_IBIAS_IN - bias. <sup>5</sup>                  | - Control v                                                                                                                                                                                                           | oltage to bottom side of sensor's column                                              | 0 V                 |  |  |
| POT 1 through POT 4 configuration data. See Section 7 for each pot description. | 15:8                                                         |       | delay buffe                                                   | 096. Control voltage to respective sensor<br>r voltage. Decreasing this voltage increases                                                                                                                             |                                                                                       |                     |  |  |
|                                                                                 | 23:16                                                        |       | delay buffe                                                   | 096. Control voltage to respective sensor voltage. Decreasing this voltage increases                                                                                                                                  |                                                                                       |                     |  |  |
|                                                                                 |                                                              |       |                                                               | <b>POT4 / HST_RO_IBIAS</b> – see register 0x097. Control voltage to the ring with capacitors oscillator (selected by register 0x047). Increasing this voltage increases the speed of the oscillator. <sup>5</sup>     |                                                                                       |                     |  |  |
| 0x028                                                                           | POT_REG8_TO_5                                                |       |                                                               | V1                                                                                                                                                                                                                    | Read/Write                                                                            |                     |  |  |
|                                                                                 |                                                              | 7:0   | POT5 / HST_OSC_VREF_IN – oscillator.5                         | <b>POT5 / HST_OSC_VREF_IN</b> – see register 0x097. Reference voltage for relaxation oscillator. <sup>5</sup>                                                                                                         |                                                                                       |                     |  |  |
|                                                                                 |                                                              | 15:8  |                                                               | or delay bu                                                                                                                                                                                                           | 098. Control voltage to respective sensor ffer voltage. Decrease in voltage increases |                     |  |  |
|                                                                                 | ough POT 8 configuration data. n 7 for each pot description. | 23:16 |                                                               | POT7 / HST_OSC_CTL – see register 0x098. Control voltage to the relaxation oscillator (selected by register 0x047). Decrease in voltage increases the speed of                                                        |                                                                                       |                     |  |  |
|                                                                                 |                                                              | 31:24 |                                                               | <b>POT8 / HST_A_NDELAY</b> – see register 0x099. Control voltage to respective sensor pin. It is the A side n transistor delay buffer voltage. Decrease in voltage increases delay of side n transistor. <sup>5</sup> |                                                                                       |                     |  |  |
| 0x029                                                                           | POT_REG12_TO_9                                               |       |                                                               | V1                                                                                                                                                                                                                    | Read/Write                                                                            | 0xF527_0000         |  |  |
|                                                                                 | ough POT 12 configuration data.                              | 7:0   | POT9 / COL_TOP_IBIAS_IN -                                     | Control vo                                                                                                                                                                                                            | Itage to top side of sensor's column bias. <sup>5</sup>                               | 0.025 V             |  |  |
| See Sectio                                                                      | n 7 for each pot description.                                | 15:8  | POT10 / HST_OSC_R_BIAS – and without capacitors. <sup>5</sup> | Control vol                                                                                                                                                                                                           | tage to current sink of ring oscillators with                                         | 0.0135 V            |  |  |







|            |                                                                                     | 23:16 | POT11 / VAB – Controls the                                                                                                                                                                                                                                         | pixel anti-bl | oom transistor voltage. <sup>5, 6</sup>                                              | 0.5 V                   |  |
|------------|-------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------|-------------------------|--|
|            |                                                                                     | 31:24 |                                                                                                                                                                                                                                                                    |               | I voltage to the ring without capacitor<br>Increasing this voltage increases the spe |                         |  |
| 0x02A      | POT_REG13                                                                           |       |                                                                                                                                                                                                                                                                    | V1            | Read/Write                                                                           | 0x0000_003A             |  |
|            | on 7 for each pot description.                                                      | 7:0   | POT13 / VRST – see register                                                                                                                                                                                                                                        | 0x099. Cor    | ntrols the pixel reset voltage. <sup>5</sup>                                         | 0 V                     |  |
| 0x02B      | LED_GP                                                                              |       |                                                                                                                                                                                                                                                                    | V1, V4        | Read/Write                                                                           | 0×0000_0000             |  |
| General p  | urpose LED control.                                                                 | 7:0   | LED7 LED0 - Bits [7:0] will I                                                                                                                                                                                                                                      | ight up LED   | _IO-8 through LED_IO-1 when written wi                                               | th a '1', respectively. |  |
| 0x02D      | SW_RESET                                                                            |       |                                                                                                                                                                                                                                                                    | V1, V4        | Write-only, Self-clearing                                                            | 0×0000_0000             |  |
| Software i | reset                                                                               | 0     | <b>RESET</b> - <i>sw_rst</i> . When assert bit is self-clearing.                                                                                                                                                                                                   | ed, will rese | t the entire FPGA, including control and                                             | status registers. This  |  |
| 0x02E      | HST_SETTINGS                                                                        |       |                                                                                                                                                                                                                                                                    | V1, V4        | Read-only                                                                            |                         |  |
|            |                                                                                     | 0     | <b>HST_SW_CTL_EN</b> - When '1', the hstAllWEn pin to the sensor will be directly controlled by the sw_hst_all_wen bit. When '0', hstAllWEn will be controlled by FPGA logic.                                                                                      |               |                                                                                      |                         |  |
| High Spee  | d timing control                                                                    | 1     | <b>SW_HSTALLWEN</b> - Will directly drive the hstAllWEn pin to the sensor when <i>HST_sw_ctl_en</i> is '1'; e.g., when both <b>HST_SW_CTL_EN</b> and <b>SW_HSTALLWEN</b> are '1', then the hstAllWEn pin to the sensor will be driven to a logical '1' (i.e. high) |               |                                                                                      |                         |  |
| 0x02F      | STAT_REG_SRC                                                                        |       |                                                                                                                                                                                                                                                                    | V1, V4        | Read-clear                                                                           |                         |  |
|            |                                                                                     | 0     | SRAM_READY- sensor reado                                                                                                                                                                                                                                           | ut is compl   | ete                                                                                  |                         |  |
|            |                                                                                     | 1     | STAT_COARSE - Coarse Trigg                                                                                                                                                                                                                                         | er detected   | l                                                                                    |                         |  |
| Status Reg | gister, Source.                                                                     | 2     | STAT_FINE - Fine Trigger detected                                                                                                                                                                                                                                  |               |                                                                                      |                         |  |
|            | the source logic for clearable status bits, STAT_REG contains read-only copies. All | 3     | <b>STAT_W3TOPAEDGE1</b> – W3 shot rising edge of shutter 3                                                                                                                                                                                                         |               | GE1 edge detect monitor detected. This A in hemisphere A.                            | s is a diagnostic one-  |  |
|            | TAT_REG_SRC register will be cleared e register is read, except for the             | 4     | <b>STAT_W3TOPBEDGE1</b> - W3_ shot rising edge of shutter 3                                                                                                                                                                                                        |               | GE1 edge detect monitor detected. This<br>A in hemisphere B.                         | is a diagnostic one-    |  |
| •          | ure Sensor and the Pressure Sensor register 0x02F to read these bits                | 5     |                                                                                                                                                                                                                                                                    | Readout In    | Progress; Indicates the start of an ADC re                                           | ead cycle in which 32   |  |
|            |                                                                                     | 6     | <b>STAT_SENSREADDONE</b> - Ser sensor readout is complete                                                                                                                                                                                                          | nsor Readou   | ut Complete – Asserted by ADC control                                                | logic; indicates that   |  |







|                                                                                 | 7     |                                                                                                                                  |               | it Started - Indicates that SRAM reado       | ut has started. This is |  |  |  |
|---------------------------------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------|-------------------------|--|--|--|
|                                                                                 |       |                                                                                                                                  |               | hich is controlled by software               | adout is complete (all  |  |  |  |
|                                                                                 | 8     | <b>STAT_SRAMREADDONE</b> - SRAM Readout Complete – Indicates that SRAM readout is complete (a pixels have been read out of SRAM) |               |                                              |                         |  |  |  |
|                                                                                 | 9     | STAT_HSTCONFIGSTART - HS                                                                                                         |               | tion start                                   |                         |  |  |  |
|                                                                                 | 10    | _                                                                                                                                |               | ured – Asserted when all five ADCs have      | e been configured       |  |  |  |
|                                                                                 | 11    | STAT_POTSCONFIGURED – a                                                                                                          |               |                                              | <u> </u>                |  |  |  |
|                                                                                 | 12    | STAT_HST_ALL_W_EN_DETE                                                                                                           | CTED - hst_c  | all_w_en detected                            |                         |  |  |  |
|                                                                                 | 13    | STAT_TIMERCOUNTERRESET                                                                                                           | – indicates   | that the timer (see 0x03C and 0x03D)         | has been reset          |  |  |  |
|                                                                                 |       | STAT_ARMED - 'ADCs configu                                                                                                       | ıred' AND 'p  | ots configured' AND <b>TRIGGER_CTL</b> [0] A | AND 'HST_Configured'    |  |  |  |
|                                                                                 | 14    | AND NOT 'coarse trigger det                                                                                                      | tected' AND   | NOT 'fine trigger detected'. Note that       | t all these conditions  |  |  |  |
|                                                                                 |       | must be met for ARMED to b                                                                                                       |               |                                              |                         |  |  |  |
|                                                                                 | 27:16 | <b>STAT_TEMP</b> - Temperature S                                                                                                 |               |                                              |                         |  |  |  |
|                                                                                 | 31:28 | STAT_PRESS - Pressure Senso                                                                                                      | or (future us | e)                                           |                         |  |  |  |
| 0x030 STAT_REG2                                                                 |       |                                                                                                                                  | V1, V4        | Read-only                                    |                         |  |  |  |
| Status Register 2. (Read-only duplicate of                                      | 31:0  | Read-only shadow bits of STAT_REG2_SRC (0x031). Reading this register has no effect on these bit                                 |               |                                              |                         |  |  |  |
| STAT_REG2_SRC)                                                                  | 31.0  | values. To clear the applicable bits, <b>STAT_REG2_ SRC</b> must be read. See 0x031 for bit assignments                          |               |                                              |                         |  |  |  |
| 0x031 STAT_REG2_SRC                                                             |       |                                                                                                                                  | V1, V4        | Read- clear                                  |                         |  |  |  |
|                                                                                 | 0     | <b>FPA_IF_TO</b> - When this bit is readout process                                                                              | asserted hig  | gh, a timeout error has occurred during      | g the sensor-to-SRAM    |  |  |  |
| Status Davistas 2 Causes                                                        | 1     | SRAM_RO_TO - When asserted high, this bit indicates that a timeout has occurred while reading an SRAM row.                       |               |                                              |                         |  |  |  |
| Status Register 2, Source. Contains the source logic for clearable status bits, |       | PIXELRD_TOUT_ERR - When                                                                                                          | asserted hig  | gh, this bit indicates that the overall se   | ensor readout process   |  |  |  |
| whereas <b>STAT_REG2</b> contains read-only copies.                             | 2     | has timed out. It also indicates that the internal transmit data pipeline has reverted from selecting                            |               |                                              |                         |  |  |  |
| All bits in STAT_REG2_SRC register will be                                      |       | , , , , , ,                                                                                                                      | ata back to   | Response (i.e., status) data to re-esta      | blish communications    |  |  |  |
| cleared when the register is read. See Section 12                               |       | with the host.                                                                                                                   |               |                                              |                         |  |  |  |
| for additional details. Use register 0x030 to read                              |       |                                                                                                                                  | _             | h and the RS422 port is enabled, thi         |                         |  |  |  |
| these bits                                                                      | 3     | timeout has occurred within the RS422 transmit logic, and the UART TX module has reset itself to recover from the condition.     |               |                                              |                         |  |  |  |
|                                                                                 |       |                                                                                                                                  | asserted hig  | h and the RS422 port is enabled, thi         | s bit indicates that a  |  |  |  |
|                                                                                 |       | <b>UART_RX_TO_RST</b> - When asserted high and the RS422 port is enabled, this bit indicates that a                              |               |                                              |                         |  |  |  |
|                                                                                 | 4     | timeout has occurred within the RS422 receive logic, and the UART RX module has reset itself to recover from the condition.      |               |                                              |                         |  |  |  |







| 0x032 ADC_BYTECOUNTER               |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                     | V1, V4                                                                                                 | Read-only                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                             |  |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ADC Byte Counter                    | 25:0                                                                                                                                                                                                                                                                                | pixels (in bytes) that have been is read after a system "hang" the error occurred during se module has likely operated no caused by a failure in the AI                                             | en read from<br>has been of<br>nsor readof<br>ormally. If it<br>OC/SRAM m<br>on. Since th              | er output of the ADC/SRAM readout more output of the ADC/SRAM readout more that image sensor and written into the detected (and prior to a reset), it can be ff. If it contains a value of zero, then the tis a non-zero value, then this may indicated in the sense of the sense output of the FPG with a system reset.                            | e SRAM. If this register e used to determine if e ADC/SRAM readout ate that the error was he pixel/byte number                              |  |  |  |
| 0x033 RBP_PIXEL_CNTR                |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                     | V1, V4                                                                                                 | Read-only                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                             |  |  |  |
| Read Burst Processing Pixel Counter | 23:0                                                                                                                                                                                                                                                                                | bytes) that have been read for<br>read after a system "hang" had<br>error occurred at the TX FIFO<br>of zero, then the ADC/SRAM of<br>If it is a non-zero value, the<br>steering/read_burst_process | rom the tra<br>as been det<br>output in the<br>module has<br>sen this ma<br>ing module<br>e this count | ng/read_burst_processing module which insmit FIFO after being read from the SI tected (and prior to a reset), it can be used he readout pipeline during SRAM readoff likely operated normally, and the error ay indicate that the error was caused, where the value contained is the pixely er is an integral part of the FPGA logic (restem reset. | RAM. If this register is sed to determine if an if. If it contains a value originated elsewhere. d by a failure in the byte number that the |  |  |  |
| 0x034 DIAG_MAX_CNT_0                |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                     | V1, V4                                                                                                 | Read/Write                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                             |  |  |  |
| Diagnostic Max Count Register 0     | 7:0<br>15:8                                                                                                                                                                                                                                                                         | MAXERR_SRT - Maximum number of errors indicated by sram_ro_to (see 0x031) before the counter freezes. Maximum value allowed is 0xFF.  Unused                                                        |                                                                                                        |                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                             |  |  |  |
|                                     | 31:16                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                     |                                                                                                        | <b>MAXERR_FIT</b> - Maximum number of errors indicated by <i>uart_tx_to_rst</i> (see 0x031) before the counter freezes. Maximum value allowed is 0xFFFF.                                                                                                                                                                                            |                                                                                                                                             |  |  |  |
| 0x035 DIAG_MAX_CNT_1                |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                     | V1, V4                                                                                                 | Read/Write                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                             |  |  |  |
| Diagnostic Max Count Register 1     | MAXERR_URTR - Maximum number of errors indicated by uart_rx_to_rst (see 0x031) before the counter freezes. Maximum value allowed is 0xFFFF.  MAXERR_UTTR - Maximum number of errors indicated by fpa_if_to (see 0x031) before the counter freezes. Maximum value allowed is 0xFFFF. |                                                                                                                                                                                                     |                                                                                                        |                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                             |  |  |  |
| 0x036 DIAG_CNTR_VAL_0               |                                                                                                                                                                                                                                                                                     | TODESS MAXIMUM VAIGE GITE                                                                                                                                                                           | V1, V4                                                                                                 | Read-only                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                             |  |  |  |







| Diagnostic Counter Value 0 |                 | 7:0   | and is reset only with a syste                                                                                                                    | <b>SRT_COUNT</b> - Current value of sram_ro_to counter, which increments when <i>sram_ro_to</i> is asserted and is reset only with a system reset. Maximum value is 0xFF; when this value is reached, the counter will freeze until reset. |                                       |                         |  |  |
|----------------------------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------------|--|--|
|                            |                 | 15:8  | Unused                                                                                                                                            |                                                                                                                                                                                                                                            |                                       |                         |  |  |
|                            |                 |       |                                                                                                                                                   | of fpa if to                                                                                                                                                                                                                               | counter, which increments when fpa_i  | f to is asserted and is |  |  |
|                            |                 | 31:16 | _                                                                                                                                                 |                                                                                                                                                                                                                                            | m value is 0xFFFF; when this value is | · <del></del>           |  |  |
|                            |                 |       | will freeze until reset.                                                                                                                          |                                                                                                                                                                                                                                            |                                       |                         |  |  |
| 0x037                      | DIAG_CNTR_VAL_1 |       |                                                                                                                                                   | V1, V4                                                                                                                                                                                                                                     | Read-only                             |                         |  |  |
|                            |                 |       | URTR_COUNT - Current value                                                                                                                        | ue of uart_r                                                                                                                                                                                                                               | x_to_rst counter, which increments w  | hen uart_rx_to_rst is   |  |  |
|                            |                 | 15:0  | asserted and is reset only wit                                                                                                                    | :h a system i                                                                                                                                                                                                                              | reset. Maximum value is 0xFFFF; wher  | this value is reached,  |  |  |
| Diagnostic                 | Counter Value 1 |       | the counter will freeze until                                                                                                                     | reset.                                                                                                                                                                                                                                     |                                       |                         |  |  |
| Diagnostic                 | Counter value 1 |       | _                                                                                                                                                 | _                                                                                                                                                                                                                                          | x_to_rst counter, which increments w  |                         |  |  |
|                            |                 | 31:16 | 1                                                                                                                                                 | •                                                                                                                                                                                                                                          | reset. Maximum value is 0xFFFF; wher  | this value is reached,  |  |  |
|                            |                 |       | the counter will freeze until                                                                                                                     | reset.                                                                                                                                                                                                                                     |                                       |                         |  |  |
| 0x03A                      | TRIGGER_CTL     |       |                                                                                                                                                   | V1, V4                                                                                                                                                                                                                                     | Read/Write                            | 0×0000_0000             |  |  |
|                            |                 | 0     | 'HW_TRIG_EN' - When '1', coarse and fine triggers are passed to internal logic; when '0', triggers are ignored.                                   |                                                                                                                                                                                                                                            |                                       |                         |  |  |
| Trigger co                 | ntrol           | 1     | Unused                                                                                                                                            |                                                                                                                                                                                                                                            |                                       |                         |  |  |
|                            |                 | 2     | SW_TRIG_EN - When '1' with rest of TRIGGER_CTL bits cleared, asserting SW_TRIG_START will cause                                                   |                                                                                                                                                                                                                                            |                                       |                         |  |  |
|                            |                 |       | the FPGA to generate a coars                                                                                                                      | 1                                                                                                                                                                                                                                          |                                       | 1                       |  |  |
| 0x03B                      | SRAM_CTL        |       |                                                                                                                                                   | V1, V4                                                                                                                                                                                                                                     | Write; self-clearing                  |                         |  |  |
|                            |                 |       | READ_SRAM - Request SRAM                                                                                                                          |                                                                                                                                                                                                                                            |                                       |                         |  |  |
| Request SI                 | RAM Readoff     | 0     | When using RS422, software should send no additional command packets after setting this until after all expected burst response data is received. |                                                                                                                                                                                                                                            |                                       |                         |  |  |
| 0x03C                      | TIMER_CTL       |       |                                                                                                                                                   | V1, V4                                                                                                                                                                                                                                     | Write; self-clearing                  |                         |  |  |
| Timer con                  | trol register   | 0     | RESET_TIMER - Resets count                                                                                                                        | er when set                                                                                                                                                                                                                                | to '1'. This bit is self-clearing.    | 1                       |  |  |
| 0x03D                      | TIMER_VALUE     |       |                                                                                                                                                   | V1, V4                                                                                                                                                                                                                                     | Read-only                             |                         |  |  |
|                            |                 |       |                                                                                                                                                   |                                                                                                                                                                                                                                            |                                       | •                       |  |  |
| Current va                 | alue of timer   | 23:0  | Current timer counter value.                                                                                                                      | Increments                                                                                                                                                                                                                                 | s every second                        |                         |  |  |







| Time to w   | vait for VRESET to ramp high.          | 30:0 |         | 1 only. Time to wait for nage in a 2-frame ICARU |                                                                                                      | ramp high, in 25 ns increments. This regi          | ster is used to recover |  |
|-------------|----------------------------------------|------|---------|--------------------------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------|--|
| 0x03F       | HSTALLWEN_WAIT_TIME                    |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_0190             |  |
| hstAllWEn   | active time                            | 30:0 | Time f  | for <i>hstAllWEn</i> to be act                   | ive during p                                                                                         | pixel initialization, in 25 ns increments          |                         |  |
| 0x041       | ICARUS_VER_SEL                         |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0×0000_0000             |  |
| Salacts IC  | ARUS type, either 4 or 2 frame version | 0    | 0       | 4-frame 'Icarus2'                                |                                                                                                      |                                                    |                         |  |
| Jelects IC/ | ANOS type, either 4 or 2 frame version |      | 1       | 2-frame 'Icarus'                                 |                                                                                                      |                                                    |                         |  |
| 0x042       | FPA_ROW_INITIAL                        |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_0000             |  |
| The initial | pixel row to read off the SRAM         | 9:0  | Initial | row, between 0 and 10                            | 023 (0x000                                                                                           | <ul><li>– 0x3FF) for Icarus and Daedalus</li></ul> |                         |  |
| 0x043       | FPA_ROW_FINAL                          |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_03FF             |  |
| The final p | pixel row to read off the SRAM         | 9:0  | Final r | ow, between 0 and 102                            | 3 (0x000 –                                                                                           | 0x3FF) . Must be greater than or equal             | to FPA_ROW_INITIAL      |  |
| 0x044       | FPA_FRAME_INITIAL                      |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0×0000_0000             |  |
| The initial | pixel frame to read off the SRAM       | 1:0  | Initial | frame, between 0 and                             | 3 for Icarus2, between 1 and 2 for Icarus                                                            |                                                    |                         |  |
| 0x045       | FPA_FRAME_FINAL                        |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_0003             |  |
| The final p | pixel frame to read off the SRAM       | 1:0  |         | frame, between 0 and 1<br>A_FRAME_INITIAL        | d 3 for Icarus2, between 1 and 2 for Icarus. Must be greater than or equal                           |                                                    |                         |  |
| 0x046       | FPA_DIVCLK_EN_ADDR                     |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_0000             |  |
| Enable the  | e HST <i>divClk</i> output             | 0    | 0       | Disable HST divClk                               |                                                                                                      |                                                    | 1                       |  |
| Ellable til | e nsi <i>divei</i> k odtput            | U    | 1       | 1 Enable HST divClk                              |                                                                                                      |                                                    |                         |  |
| 0x047       | FPA_OSCILLATOR_SEL_ADDR                |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0x0000_0000             |  |
|             |                                        |      | 00      | Relaxation oscillator                            |                                                                                                      |                                                    |                         |  |
| Select the  | e oscillator for the ROIC.             | 1:0  | 01      | Ring oscillator                                  |                                                                                                      |                                                    |                         |  |
|             |                                        |      | 10      | Ring oscillator (witho                           | out caps)                                                                                            |                                                    |                         |  |
| 0.045       |                                        |      | 11      | External clock                                   |                                                                                                      | 2 1644                                             | 0.0000.0000             |  |
| 0x04A       | VRESET_HIGH_VALUE                      |      |         |                                                  | V1, V4                                                                                               | Read/Write                                         | 0×0000_0000             |  |
| <b>5</b>    |                                        |      |         |                                                  |                                                                                                      | es programmed VRESET value when Fr                 |                         |  |
| Frame 0 a   | ind 3 VRESET value                     | 7:0  |         |                                                  | =                                                                                                    | period for a 2-frame Icarus. Used                  | -                       |  |
|             |                                        |      |         |                                                  | ARUS_VER_SEL. POT13 programmed value during 2-frame Icarus recovery oltage; 0x00 is minimum voltage. |                                                    |                         |  |
|             |                                        |      |         |                                                  |                                                                                                      |                                                    | frame Icarus            |  |







| 0x04C      | MISC_SENSOR_CTL                                                                                               |                   |                                                         |                                                                                                                                                                                                      | V1, V4                                                                                 | Read/Write                                                                             | 0x0000_01BE          |
|------------|---------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------|
|            |                                                                                                               |                   | 1                                                       | ACCUMULATION_CTL – If '1', invoke accumulation mode; relevant sensor pins are controlled by bits L-4 of this register. If '0', those sensor pins are managed by manual shutter control. <sup>5</sup> |                                                                                        |                                                                                        |                      |
|            | Miscellaneous sensor control for Icarus                                                                       | 1                 | HST_T                                                   | ST_ANRST_EN – Must                                                                                                                                                                                   | have bit 0                                                                             | enabled of this register. If '1', assert the emisphere of the sensor. If '0', disable  | ne High-Speed Timing |
|            |                                                                                                               | 2                 | HST_T                                                   | ST_BNRST_EN – Must                                                                                                                                                                                   | have bit 0                                                                             | enabled of this register. If '1', assert the memisphere of the sensor. If '0', disable | ne High-Speed Timing |
| Miscellane |                                                                                                               | 3                 | _                                                       |                                                                                                                                                                                                      |                                                                                        | enabled of this register. If '1', assert there of the sensor. If '0', disable this pin | • .                  |
|            | 4                                                                                                             | _                 |                                                         |                                                                                                                                                                                                      | enabled of this register. If '1', assert there of the sensor. If '0', disable this pin |                                                                                        |                      |
|            | 5                                                                                                             | pin. <sup>5</sup> |                                                         | •                                                                                                                                                                                                    | el reset transistor enable pin on the sen                                              | ·                                                                                      |                      |
|            |                                                                                                               | 6                 | is enal                                                 | <b>HST_CONT_MODE</b> – If '1', enable continuous mode. Shutter timing generation repeats if the oscillator is enabled. <sup>5</sup>                                                                  |                                                                                        |                                                                                        |                      |
|            |                                                                                                               | 7                 | COL_DCD_EN – If '1', enable column decode. <sup>5</sup> |                                                                                                                                                                                                      |                                                                                        |                                                                                        |                      |
|            |                                                                                                               | 8                 | COL_R                                                   | READOUT_EN – If '1', e                                                                                                                                                                               | nable the p                                                                            | ad drivers for the analog image channe                                                 | s. <sup>5</sup>      |
| 0x050      | MANUAL_SHUTTERS_MODE                                                                                          |                   |                                                         |                                                                                                                                                                                                      | V1, V4                                                                                 | Read/Write                                                                             | 0×0000_0000          |
|            | nutters Mode select. When bit 0 is set,                                                                       |                   | MANSHUT_MODE                                            |                                                                                                                                                                                                      |                                                                                        |                                                                                        |                      |
|            | will generate manual shutters signals DIC when the fine trigger is detected.                                  | 0                 | 0                                                       | 0 Normal 'High Speed' Mode                                                                                                                                                                           |                                                                                        |                                                                                        |                      |
| i          | , the on-chip High Speed Timing will be                                                                       |                   | 1                                                       | Manual Shutters Mo                                                                                                                                                                                   | de                                                                                     |                                                                                        |                      |
| 0x051      | W0_INTEGRATION                                                                                                |                   |                                                         |                                                                                                                                                                                                      | V1, V4                                                                                 | Read/Write                                                                             | 0x0000_0000          |
|            | Manual Shutters image integration time register for frame 0 of ICARUS A-side.                                 |                   |                                                         | Amount of integration time in 25 ns steps.                                                                                                                                                           |                                                                                        |                                                                                        |                      |
| 0x052      | W0_INTERFRAME                                                                                                 |                   |                                                         |                                                                                                                                                                                                      | V1, V4                                                                                 | Read/Write                                                                             | 0x0000_0000          |
| between    | Manual Shutters image interframe time- time between acquisitions for frames 0 and 1 of 29:0 // ICARUS A-side. |                   |                                                         | Amount of interframe time in 25 ns steps.                                                                                                                                                            |                                                                                        |                                                                                        |                      |
| 0x053      | W1_INTEGRATION                                                                                                |                   |                                                         |                                                                                                                                                                                                      | V1, V4                                                                                 | Read/Write                                                                             | 0x0000_0000          |







|                                                                                                               | nutters image integration time register 1 of ICARUS A-side.                  | 29:0 | Amount of integration time i | n 25 ns steps. |            |             |
|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|------|------------------------------|----------------|------------|-------------|
| 0x054                                                                                                         | W1_INTERFRAME                                                                |      |                              | V1, V4         | Read/Write | 0x0000_0000 |
|                                                                                                               | hutters image interframe time- time acquisitions for frames 1 and 2 of side. | 29:0 | Amount of interframe time i  | n 25 ns steps. |            |             |
| 0x055                                                                                                         | W2_INTEGRATION                                                               |      |                              | V1, V4         | Read/Write | 0×0000_0000 |
|                                                                                                               | nutters image integration time register 2 of ICARUS A-side.                  | 29:0 | Amount of integration time i | n 25 ns steps. |            | ·           |
| 0x056                                                                                                         | W2_INTERFRAME                                                                |      |                              | V1, V4         | Read/Write | 0×0000_0000 |
|                                                                                                               | hutters image interframe time- time acquisitions for frames 2 and 3 of side. | 29:0 | Amount of interframe time i  | n 25 ns steps. |            |             |
| 0x057                                                                                                         | W3_INTEGRATION                                                               |      |                              | V1, V4         | Read/Write | 0x0000_0000 |
|                                                                                                               | nutters image integration time register 3 of ICARUS A-side.                  | 29:0 | Amount of integration time i | n 25 ns steps. |            | ,           |
| 0x058                                                                                                         | W0_INTEGRATION_B                                                             |      |                              | V1, V4         | Read/Write | 0×0000_0000 |
|                                                                                                               | nutters image integration time register 0 of ICARUS B-side.                  | 29:0 | Amount of integration time i | n 25 ns steps. |            | ·           |
| 0x059                                                                                                         | W0_INTERFRAME_B                                                              |      |                              | V1, V4         | Read/Write | 0x0000_0000 |
|                                                                                                               | hutters image interframe time-time acquisitions for frames 0 and 1 of side.  | 29:0 | Amount of interframe time i  | n 25 ns steps. |            |             |
| 0x05A                                                                                                         | W1_INTEGRATION_B                                                             |      |                              | V1, V4         | Read/Write | 0x0000_0000 |
|                                                                                                               | nutters image integration time register 1 of ICARUS B-side.                  | 29:0 | Amount of integration time i | n 25 ns steps. |            |             |
| 0x05B                                                                                                         | W1_INTERFRAME_B                                                              |      |                              | V1, V4         | Read/Write | 0x0000_0000 |
| Manual Shutters image interframe time- time between acquisitions for frames 1 and 2 of 29:0 // ICARUS B-side. |                                                                              |      | Amount of interframe time i  | n 25 ns steps. |            |             |







| 0x05C                                                                                                      | W2_INTEGRATION_B                                            |      |                                                                   | V1, V4                                     | Read/Write                                                               | 0×0000_0000  |  |
|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------|-------------------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------|--------------|--|
| Manual Shutters image integration time register for frame 2 of ICARUS B-side.                              |                                                             |      | Amount of integration time i                                      | Amount of integration time in 25 ns steps. |                                                                          |              |  |
| 0x05D                                                                                                      | W2_INTERFRAME_B                                             |      | V1, V4                                                            | Read/Write                                 | 0x0000_0000                                                              |              |  |
| Manual Shutters image interframe time- time between acquisitions for frames 2 and 3 of 29:0 ICARUS B-side. |                                                             |      | Amount of interframe time in                                      | n 25 ns step                               | S.                                                                       |              |  |
| 0x05E                                                                                                      | W3_INTEGRATION_B                                            |      |                                                                   | V1, V4                                     | Read/Write                                                               | 0x0000_0000  |  |
|                                                                                                            | nutters image integration time register 3 of ICARUS B-side. | 29:0 | Amount of integration time i                                      | n 25 ns step                               | s.                                                                       |              |  |
| 0x082                                                                                                      | SENSOR_VOLT_STAT                                            |      |                                                                   | V1                                         | Read-only                                                                |              |  |
|                                                                                                            |                                                             | 0    | SENSOR_POSN - pos_n                                               |                                            |                                                                          |              |  |
|                                                                                                            |                                                             | 1    | SENSOR_NEGP - neg_p                                               |                                            |                                                                          |              |  |
| Status of s                                                                                                | ensor voltage-related signals                               | 2    | ICARUS_DET - Derived from the sensor_det[1:0] bits from the PCB   |                                            |                                                                          |              |  |
|                                                                                                            |                                                             | 3    | DAEDALUS_DET - Derived from the sensor_det[1:0] bits from the PCB |                                            |                                                                          |              |  |
|                                                                                                            |                                                             | 4    | HORUS_DET - Derived from the sensor_det[1:0] bits from the PCB    |                                            |                                                                          |              |  |
|                                                                                                            |                                                             | 5    | SENSOR_POWER - Asserted according to the truth table in Table 4   |                                            |                                                                          |              |  |
| 0x083                                                                                                      | SENSOR_VOLT_CTL                                             |      |                                                                   | V1                                         | Read/Write                                                               | 0×0000_0000  |  |
| Control of                                                                                                 | Sensor Voltage Supply                                       | 0    |                                                                   | <del>-</del> -                             | wer_on is enabled when pos_n, neg_p, nsor_power_on is enabled regardless | <del>-</del> |  |
| 0x090                                                                                                      | ADC_CTL                                                     |      |                                                                   | V1, V4                                     | Write; Self-clearing                                                     |              |  |
|                                                                                                            |                                                             | 0    | Configure ADC 1                                                   |                                            |                                                                          |              |  |
|                                                                                                            |                                                             | 1    | Configure ADC 2                                                   |                                            |                                                                          |              |  |
| Control of                                                                                                 | TI8548 ADCs                                                 | 2    | Configure ADC 3                                                   |                                            |                                                                          |              |  |
| 3 4                                                                                                        |                                                             |      | Configure ADC 4                                                   |                                            |                                                                          |              |  |
|                                                                                                            |                                                             |      | Configure ADC 5                                                   |                                            |                                                                          |              |  |
| 0x091                                                                                                      | ADC1_CONFIG_DATA                                            |      |                                                                   | V1, V4                                     | Read/Write                                                               | 0x81A8_83FF  |  |
| Configuration data to be manage ADC 1 9:0                                                                  |                                                             |      | Internal reference DAC settir                                     | ng (1 LSB = ir                             | nternal Vref / 1024)                                                     | •            |  |







|            |                                      | 13    | Internal reference voltage ('C                                | )' = 2.5 V, '1 | L' = 3 V)                             |             |  |
|------------|--------------------------------------|-------|---------------------------------------------------------------|----------------|---------------------------------------|-------------|--|
|            |                                      | 15    | Internal reference enable                                     |                |                                       |             |  |
|            |                                      | 24:19 | Voltage multiplier controls                                   |                |                                       |             |  |
| 0x092      | ADC2_CONFIG_DATA                     |       |                                                               | V1, V4         | Read/Write                            | 0x81A8_83FF |  |
|            |                                      | 9:0   | Internal reference DAC settin                                 | ng (1 LSB = i  | nternal Vref / 1024)                  |             |  |
| Configurat | ion data to be manage ADC 2          | 13    | Internal reference voltage ('C                                | )' = 2.5 V, '1 | L' = 3 V)                             |             |  |
| Comigurat  | non data to be manage ADC 2          | 15    | Internal reference enable                                     |                |                                       |             |  |
|            |                                      | 24:19 | Voltage multiplier controls                                   |                |                                       |             |  |
| 0x093      | ADC3_CONFIG_DATA                     |       |                                                               | V1, V4         | Read/Write                            | 0x81A8_83FF |  |
|            |                                      |       | Internal reference DAC settir                                 | ng (1 LSB = i  | nternal Vref / 1024)                  |             |  |
| Configurat | ion data to be manage ADC 3          | 13    | Internal reference voltage ('C                                | )' = 2.5 V, '1 | L' = 3 V)                             |             |  |
| Comigurat  | doit data to be manage ADC 3         | 15    | Internal reference enable                                     |                |                                       |             |  |
|            |                                      |       | Voltage multiplier controls                                   |                |                                       |             |  |
| 0x094      | ADC4_CONFIG_DATA                     |       |                                                               | V1, V4         | Read/Write                            | 0x81A8_83FF |  |
|            |                                      | 9:0   | Internal reference DAC setting (1 LSB = internal Vref / 1024) |                |                                       |             |  |
| Configurat | ion data to be manage ADC 4          | 13    | Internal reference voltage ('C                                | )' = 2.5 V, '1 | L' = 3 V)                             |             |  |
| Comigurat  | non data to be manage ADC 4          | 15    | Internal reference enable                                     |                |                                       |             |  |
|            |                                      | 24:19 | Voltage multiplier controls                                   |                |                                       |             |  |
| 0x095      | ADC5_CONFIG_DATA                     |       |                                                               | V1, V4         | Read/Write                            | 0x81A8_83FF |  |
| Configurat | ion data to be written to ADC 5 (see | 9:0   | ADC5_VREF – Internal refere                                   | nce DAC se     | etting (1 LSB = internal Vref / 1024) | 1111111111  |  |
| _          | truments document SBAS543A for       | 13    | ADC5_VREF3 – Internal refer                                   |                | ge ('0' = 2.5 V, '1' = 3 V)           | 1           |  |
| details)   | traments accument SBASS4SA for       | 15    | ADC5_INT – Internal referen                                   | ce enable      |                                       | 1           |  |
| ,          |                                      | 24:19 | ADC5_MULT – Voltage multi                                     | plier contro   | ols                                   | 110101      |  |
| 0x096      | ADC5_DATA_1                          |       |                                                               | V1, V4         | Read-only                             |             |  |
| POT 2 and  | POT 2 and 3 data. 15:0               |       | MON_CH2 / MON_HST_A_PDELAY – see register 0x027               |                |                                       |             |  |
|            | Full scale is 0-5 V.                 |       | MON_CH3 / MON_HST_B_NDELAY – see register 0x027               |                |                                       |             |  |
|            | n 7 for each pot description.        | 31.10 |                                                               |                |                                       |             |  |
| 0x097      | ADC5_DATA_2                          |       |                                                               | V1, V4         | Read-only                             |             |  |
| POT 4 and  | 5 data.                              | 15:0  | MON_CH4 / MON_HST_RO_                                         | IBIAS – see    | e register 0x027                      |             |  |







| Full scale is 0-5 V. See Section 7 for each pot description.           |                                                                     | 31:16                      | MON_CH5 / MON_HST_OSC_VREF_IN – see register 0x028 |                                                               |                                           |                        |  |
|------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------|----------------------------------------------------|---------------------------------------------------------------|-------------------------------------------|------------------------|--|
| 0x098                                                                  | ADC5_DATA_3                                                         |                            |                                                    | V1, V4                                                        | Read-only                                 |                        |  |
| POT 6 and                                                              | 7 data.                                                             | 15:0                       | MON_CH6 / MON_HST_B_P                              | <b>DELAY</b> – se                                             | e register 0x028                          |                        |  |
| Full scale is                                                          |                                                                     | 31:16                      | MON_CH7 / MON_HST_OSC                              | _CTL – see                                                    | register 0x028                            |                        |  |
| See Section                                                            | n 7 for each pot description.                                       | 31.10                      |                                                    |                                                               |                                           | 1                      |  |
| 0x099                                                                  | ADC5_DATA_4                                                         |                            |                                                    | V1, V4                                                        | Read-only                                 |                        |  |
| POT 8 and                                                              | VRST data.                                                          | 15:0                       | MON_CH8 / MON_HST_A_N                              | I <b>DELAY</b> – se                                           | ee register 0x028                         |                        |  |
| Full scale is                                                          | s 0-5 V.                                                            | 31:16                      | MON_VRST - Note this is the                        | output of t                                                   | the POT 13 conditioning circuit (TP19) th | at is connected to the |  |
| See Section 7 for each pot description.                                |                                                                     | 31.10                      | sensor. The direct output of                       | POT 13 (TP                                                    | 24) is not connected to ADC5. See regist  | ter 0x02A              |  |
| 0x09A                                                                  | ADC5_PPER                                                           |                            |                                                    | V1, V4                                                        | Read/Write                                | 0x001E_8480            |  |
| Polling per                                                            | iod for ADC5, in 20MHz clock cycles.                                | 27:0                       | ADC5 polling period. Default                       | ADC5 polling period. Default is 100ms = 2,000,000 = 0x1E_8480 |                                           |                        |  |
| 0х09В                                                                  | ADC_STANDBY (version < rev AD) ADC_RESET (versions rev AD to presen | nt)                        |                                                    | V1, V4                                                        | Read/Write                                | 0x0000_001F            |  |
|                                                                        |                                                                     | 0                          | ADC1 standby / reset                               |                                                               |                                           |                        |  |
|                                                                        | andby pins to ADC 1 through 5 (boards                               | 1                          | ADC2 standby / reset                               |                                                               |                                           |                        |  |
| before rev                                                             | eset pins to ADC 1 through 5 (for                                   | 2                          | ADC3 standby / reset                               |                                                               |                                           |                        |  |
|                                                                        | f AD to present)                                                    | 3                          | ADC4 standby / reset                               |                                                               |                                           |                        |  |
| VC1310113 01                                                           | - The to present)                                                   | 4                          | ADC5 standby / reset                               |                                                               |                                           |                        |  |
| 0x0A0                                                                  | TEMP_SENSE_PPER                                                     |                            |                                                    | V1, V4                                                        | Read/Write                                | 0x001E_8480            |  |
|                                                                        | eriod for TI TMP275 temperature<br>40MHz clock cycles.              | Temperature sensor polling | period. Defa                                       | ault is 50ms = 2,000,000 = 0x1E_8480                          |                                           |                        |  |
| 0x0A1                                                                  | TEMP_SENSE_DATA                                                     |                            |                                                    | V1, V4                                                        | Read-only                                 |                        |  |
| Data read from TI TMP275 temperature sensor 11:0 Temperature sensor da |                                                                     |                            | Temperature sensor data rea                        | nd out durir                                                  | ng most recent poll                       | •                      |  |





## 12 Error Recovery and Diagnostics

Numerous design and development techniques have been utilized in the NSGCC FPGA to ensure that it operates as reliably as possible; however, due to the harsh operational environment that the system is targeted for, logic failures are unavoidable and will occur. In this case, the FPGA's error recovery and diagnostic features are critical, enabling the FPGA to recover from an error and allowing the user to diagnose the root cause so that corrections can be made. These features include

- Status registers, counters and timers in various parts of the sensor and SRAM readout pipelines to detect when logic modules and state machines have "hung" and to assist in determining the root causes
- Automatic resets in the RS422 logic section, which ensure that communications can be reestablished in case of an error in the RS422 modules
- A software reset to enable the user to return the board to its default configuration when desired.

The following sub-sections describe the implemented error recovery and diagnostic features.

### 12.1 Software Reset

A software reset has been implemented which resets all logic within the FPGA. To initiate a software reset, write a '1' to the **RESET** subregister. This bit will self-clear after being written. Note that all internal FPGA logic will be reset to their default values, including the control registers.

### 12.2 Automatic Resets on RS422 Transmit and Receive

To ensure that serial communications are maintained in the event of Single Event Upsets in the RS422 logic, automatic resets in both the RS422 transmit and receive sections have been implemented. In the event of a detected "hang" in the RS422 logic, all modules related to reception of command packets and transmission of response packets are reset automatically. The modules which are reset are the RS422, Steering, and Packet Encode/Decode modules. Note that a "hang" condition is determined when an operation takes much longer than under normal operation.

The transmit RS422 section (which generates response packets to the host) is determined to be hung when a byte transfer takes 1 ms, which is much longer than is expected under normal conditions. The receive RS422 section (where the FPGA receives a command packet) is determined to be hung when a byte transfer takes longer than 100 ms (to account for host system performance).

When a "hang" in either the transmit or receive RS422 sections is detected, the appropriate bits in the STAT\_REG2\_SRC and STAT\_REG2 registers are asserted.

### 12.3 ADC to SRAM module Timeout

A counter exists in the ADC to SRAM module which can be useful in determining the root cause of errors which occur during image sensor read off. This will count the number of pixels (in bytes) that have been read out from the sensor and written into the SRAMs. During normal operation, this counter will count to the final pixel/byte and reset itself to zero. In the event of an FPGA hang, the value held by this counter could be helpful in diagnosing a fault. If an error or FPGA hang occurs, and RS422 communications have been maintained, a non-zero value in this counter indicates that the error occurred during image sensor





readout, while the value indicates the last pixel that was read out successfully. If the counter contains a value of zero, then the root cause of the error likely resides elsewhere.

To enable the host to read the counter value, it has been connected to read-only status register **ADC\_BYTECOUNTER**. Note that this register cannot be cleared by software; to clear the register, the counter itself must be cleared by returning the ADC-to-SRAM module to its default state (which may require resetting the FPGA).

### 12.4 FPA Interface Module Timeout

Additional indicators of an error occurring during image sensor readoff reside in the FPA Interface Module, which controls image sensor timing during image readoff.

To control sensor readoff, the FPA Interface module sends control signals to the ADC to SRAM module. Two of the more useful ones for error detection are adcReadWriteStart (which initiates an 8-channel ADC read) and readOffDone (which indicates that all desired frames/pixels have been read out from the sensor). To determine if the state machine in this module has hung, the time between these signals is monitored. Since the time between adcReadWriteStart pulses is normally 2.875  $\mu$ s, and the time between the last adcReadWriteStart pulse and readOffDone is 925 ns, a counter has been implemented that will assert an error bit if the time for either of these events exceeds 2 × 2.875  $\mu$ s, or 5.75  $\mu$ s. This error bit is called  $fpa_if_i$  to, and it resides in the **STAT\_REG2** and **STAT\_REG2\_SRC** registers.

### 12.5 SRAM Readoff Module Timeout

To assist in detecting the root cause of errors occurring during SRAM readoff, a diagnostic counter has been implemented to monitor timing in the SRAM Readoff Row module which controls SRAM readoff on a per-row basis.

To determine an error in this module, the signal *dataOutEn\_n* is monitored. This signal is low during the time when row data is being read from the SRAM; in between rows, it goes high for a small number of clock cycles. If *dataOutEn\_n* has been monitored as low for an abnormally long period of time, an error bit is asserted (this is the *sram\_ro\_to* bit in the **STAT\_REG2** and **STAT\_REG2\_SRC** registers).

During normal operation,  $dataOutEn_n$  is low for 12.8  $\mu$ s; the error bit is not asserted unless the signal has been low for 25.6  $\mu$ s.

### 12.6 Read Burst Processing Module Timeouts

A timeout counter has been implemented to determine the overall length of time that it takes for the entire image sensor readoff and SRAM readout processes to occur. If the length of time has been found to be much longer than normal, then the logic decides that an error has occurred, and two operations occur: (1) control of the transmit data pipeline within the FPGA reverts from Burst Response (i.e., pixel) data back to Response (i.e., status) data to re-enable communications with the host, and (2) the pixelrd\_timeout\_err bit in the STAT\_REG2 and STAT\_REG2\_SRC registers is asserted.







### 12.7 Resets

Due to the complexity of the radiation tolerant version of the FPGA, numerous resets are generated and used for different purposes. Table 12 lists all the resets used within the device, their modules of origin, purpose, and the logic they affect.

| Reset signal        | Driver (origin)<br>module   | Purpose                                                                                                                                                                                | Connected modules                                                                                                                                                                                      |
|---------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sys_rst_n_i         | N/A - PCB<br>reset          | System reset                                                                                                                                                                           | clocks_and_resets.vhd (used as input to other reset signals, then distributed to appropriate logic)                                                                                                    |
| sw_rst              | ctl_and_status<br>_regs.vhd | Software-controlled system reset                                                                                                                                                       | clocks_and_resets.vhd (used as input to other reset signals, then distributed to appropriate logic)                                                                                                    |
| cns_reg_rst         | clocks_and_<br>resets       | Reset signal dedicated to resetting the control and status module. Is not asserted under any condition except by sys_rst_n_i. Preserves register state in case any other reset occurs. | ctl_and_status_regs.vhd                                                                                                                                                                                |
| sys_rst /<br>sysRst | clocks_and_<br>resets       | Asserted when sys_rst_n_i or sw_rst are asserted                                                                                                                                       | timer_counter.vhd<br>Rs422.vhd<br>dummy_adc_rd.vhd                                                                                                                                                     |
| seu_rec_rst         | seu_recovery.<br>vhd        | Asserted if fpa interface times out due to SEU occur                                                                                                                                   | Connected to seu_sys_rst_bl, shot_sys_rst, and shot_sys_rst_bl signals                                                                                                                                 |
| seu_sys_rst_bl      | nsgcc_top.vhd               | OR function of sys_rst and seu_rec_rst. Used specifically to reset logic in fpa_interface.vhd that does NOT need to be held in a particular state during the shot.                     | fpa_interface.vhd – used to reset<br>all logic (and sub-modules)<br>except for the state machine and<br>related logic.                                                                                 |
| rt_shot_hold        | clocks_and_<br>resets.vhd   | Hold rad-susceptible logic in reset for 20us following fine trigger                                                                                                                    | fpa_interface.vhd – holds state machine in WAIT_FOR_FINE_ TRIG state for 20us following fine trigger. If an SEU occurs that corrupts the state machine, it will transition back to WAIT_FOR_ FINE_TRIG |
| shot_sys_rst        | nsgcc_top.vhd               | OR function of sys_rst, rt_shot_hold,<br>and seu_rec_rst                                                                                                                               | sw_trigger_ctl.vhd                                                                                                                                                                                     |
| shot_sys_rst_bl     | nsgcc_top.vhd               | Boolean version of shot_sys_rst                                                                                                                                                        | sram_readoff_top.vhd<br>adc_to_sram_read_control                                                                                                                                                       |
| timeout_rec_rst     | rs422_top.vhd               | Asserted when timeouts occur during an rs422 RX or TX transaction.                                                                                                                     | Connected to shot_comms_rst signal                                                                                                                                                                     |
| shot_comms_rst      | nsgcc_top.vhd               | OR function of timeout_rec_rst and<br>shot_sys_rst. Resets affected<br>modules if an rs422 timeout occurs                                                                              | steering.vhd<br>packet_enc_dec.vhd                                                                                                                                                                     |

Table 12: Device Resets







## 13 Icarus implementation

Information regarding the Icarus sensor interface can be found in the UXI ICARUS – Focal Plane Array Interface Document.

### 13.1 ADC Interface and Control

The FPGA controls the five analog-to-digital converters (ADCs) on the board. Four of the ADCs are used to convert the image sensor's analog pixel information into 16-bit digital data, while the fifth is used to monitor potentiometer voltages. All five ADCs are Texas Instruments ADS8568SPM, which are eight-channel 16-bit devices. Since the Icarus sensor is a 32-channel device, four of these 8channel devices (numbered ADC1 through ADC4) are required to read out all sensor channels simultaneously. The sensor quadrant and column number connectivity to ADC device number/channel number is shown in Table 13.

| Sensor           | Sensor  | ADC    | ADC     |
|------------------|---------|--------|---------|
| Quadrant         | Column  | Device | Channel |
| Top Left (A)     | 0-31    | 4      | 2       |
| Top Left (A)     | 32-63   | 4      | 3       |
| Top Left (A)     | 64-95   | 3      | 6       |
| Top Left (A)     | 96-127  | 3      | 5       |
| Top Left (A)     | 128-159 | 4      | 0       |
| Top Left (A)     | 160-191 | 4      | 1       |
| Top Left (A)     | 192-223 | 4      | 5       |
| Top Left (A)     | 224-255 | 3      | 1       |
| Top Right (B)    | 256-287 | 3      | 4       |
| Top Right (B)    | 288-319 | 3      | 7       |
| Top Right (B)    | 320-351 | 4      | 4       |
| Top Right (B)    | 352-383 | 4      | 6       |
| Top Right (B)    | 384-415 | 4      | 7       |
| Top Right (B)    | 416-447 | 3      | 0       |
| Top Right (B)    | 448-479 | 3      | 2       |
| Top Right (B)    | 480-511 | 3      | 3       |
| Bottom Left (A)  | 0-31    | 2      | 6       |
| Bottom Left (A)  | 32-63   | 2      | 0       |
| Bottom Left (A)  | 64-95   | 2      | 2       |
| Bottom Left (A)  | 96-127  | 2      | 1       |
| Bottom Left (A)  | 128-159 | 2      | 3       |
| Bottom Left (A)  | 160-191 | 2      | 7       |
| Bottom Left (A)  | 192-223 | 2      | 4       |
| Bottom Left (A)  | 224-255 | 1      | 4       |
| Bottom Right (B) | 256-287 | 1      | 6       |
| Bottom Right (B) | 288-319 | 1      | 5       |
| Bottom Right (B) | 320-351 | 1      | 7       |
| Bottom Right (B) | 352-383 | 1      | 3       |
| Bottom Right (B) | 384-415 | 1      | 2       |
| Bottom Right (B) | 416-447 | 1      | 1       |
| Bottom Right (B) | 448-479 | 1      | 0       |
| Bottom Right (B) | 480-511 | 2      | 5       |

Table 13: Sensor Channel to ADC Device Channel Connectivity







## 13.2 ADC-Potentiometer Mapping

The Icarus-configured board POT and monitor assignments are shown in Table **14**. The A0-D1 designation for channel numbers is that used in the manufacturer's data sheet.

| Pot   | Monitor Channel         | ADC5<br>Channel<br>: Pin | Function                         | Description                                                                  | Sensor<br>Pin | Nominal<br>Voltages<br>(V) |
|-------|-------------------------|--------------------------|----------------------------------|------------------------------------------------------------------------------|---------------|----------------------------|
| POT1  |                         |                          | COL_BOT_IBIAS_IN                 | Column bias for bottom<br>hemisphere of ICARUS<br>sensor.                    | 153           | 0                          |
| POT2  | MON_HST_A_<br>PDELAY    | A0: 42                   | HST_A_PDELAY                     | Delay voltage for A side<br>pixel array.<br>Increase to add delay.           | 78            | 0                          |
| РОТ3  | MON_HST_B_<br>NDELAY    | A1: 47                   | HST_B_NDELAY                     | Delay voltage for B side<br>pixel array.<br>Decrease to add delay.           | 86            | 3.3                        |
| РОТ4  | MON_HST_RO_<br>IBIAS    | B0: 49                   | HST_RO_IBIAS/<br>HST_RO_NC_IBIAS | Ring oscillator with capacitors bias voltage.                                | 46            | 2.5                        |
| РОТ5  | MON_HST_OSC_<br>VREF_IN | B1: 54                   | HST_OSC_VREF                     | Oscillator voltage reference.                                                | 87            | 2.9                        |
| РОТ6  | MON_HST_B_<br>PDELAY    | C0: 64                   | HST_B_PDELAY                     | Delay voltage for B side<br>pixel array. Increase to add<br>delay.           | 94            | 0                          |
| РОТ7  | MON_HST_OSC_<br>CTL     | C1: 59                   | HST_OSC_CTL                      | Relaxation oscillator bias control voltage.                                  | 48            | 1.45                       |
| РОТ8  | MON_HST_A_<br>NDELAY    | D0: 7                    | HST_A_NDELAY                     | Delay voltage for A side<br>pixel array. Decrease to<br>add delay.           | 70            | 3.3                        |
| РОТ9  |                         |                          | COL_TOP_IBIAS_IN                 | Column bias for top<br>hemisphere of ICARUS<br>sensor.                       | 8             | 0.025                      |
| POT10 |                         | D1: 2                    | HST_OSC_R_BIAS                   | Current sink set for ring oscillator with capacitors.                        | 16            | 0.0135                     |
| POT11 |                         |                          | VAB                              | Gate voltage of all anti-<br>bloom transistors in the<br>ICARUS pixel array. | 28            | 0.5                        |
| POT12 |                         |                          | HST_RO_NC_IBIAS                  | Ring oscillator without capacitors bias voltage.                             | 53            | 2.5                        |
| POT13 | MON_VRST                | D1: 2                    | VRST                             | Resets the voltage for all pixels.                                           | 61, 69,<br>77 | 0.3                        |

Table 14: ICARUS Pot and Monitor Assignments. See the 'UXI\_Icarus\_FPA' document for more details \*Assignment determined by resistors (see section 5.1)





### 13.3 Anti-Bloom Circuit Control

Each Icarus pixel contains an anti-bloom transistor that is designed to shunt photocurrents greater than full-well, which protects the pixel circuitry from large photo diode signal fluctuations. The gate voltage of the transistor controls the V<sub>DS</sub> at which the transistor starts conducting current; the VAB pin on the ICARUS sensor is connected to the gate of the anti-bloom transistors and enables the user to apply a voltage to it. On the Version 1.0 Board, VAB is controlled by the **VAB** subregister (aka **POT11**), which can be set using the setPotV command.

### 13.4 Sensor Power Control

Sensor power can be enabled by either the FPGA under software control, or by PCB-installed hardware circuitry. In Table 15, bypass\_sensor\_det is a bit in the SENSOR\_VOLT\_CTL register, icarus\_det is a bit in the SENSOR\_VOLT\_STAT register that is generated by the state of the

| bypass_<br>sensor_<br>det | lcarus_det | Pos_not | Neg_p | Sensor_<br>power_<br>on |
|---------------------------|------------|---------|-------|-------------------------|
| 0                         | 1          | 0       | 0     | 1                       |
| 0                         | 0          | 1       | 1     | 1                       |
| 1                         | X          | X       | X     | 1                       |

Table 15: Sensor Power Enable Truth Table

sensor\_det[1:0] pins, and *pos\_n*, and *neg\_p* are signals from PCB circuitry. The last column, *Sensor\_power\_on*, is an output signal of the FPGA; when asserted, power to the sensor is turned on.

When bypass\_sensor\_det is low (logic 0), sensor power is dependent only on the state of icarus\_det, pos\_n, and neg\_n. When it is high (logic 1), sensor power is enabled independent of any other signal. Currently the state of sensor\_det[1:0] is only applicable to Icarus in the firmware.

### 13.5 High-Speed Timing (HST) Control

The High-Speed Timing Control function is discussed in detail in *UXI ICARUS – Focal Plane Array Interface Document,* so this document will not repeat the information contained in that interface document. However, some important things to note regarding this FPGA's implementation of the HST programming sequences are:

- High Speed Timing must be configured prior to initiating the programming sequence using the
   HS\_TIMING\_DATA\_ALO, HS\_TIMING\_DATA\_AHI, HS\_TIMING\_DATA\_BLO, and HS\_TIMING\_
   DATA\_BHI registers. These four registers define the 80 bits of A and B side timing described in
   Figure 6 through 12 of the UXI ICARUS Focal Plane Array Interface Document.
- 2. The HST programming sequence is initiated when the FPGA detects the rising edge of the Coarse Trigger.







### 13.6 Manual Shutter Control

The user can override the HST function of the Icarus sensor and utilize a Manual Shutter Control function instead. Although the timing granularity is coarse compared with the HST mechanism (25 ns vs 1 ns), the user can set integration for each of the frames and/or interframe times between 25 ns and 26.8 seconds, shown in Figure 4. Since the FPGA exhibits instability in a programmed integration and interframe time close to 25 ns, the Nyquist rate becomes an issue; thus, the software limits the user from inputting integration times shorter than 75 ns. This ensures stable programmed integration and/or interframe time. Manual Shutter Control is discussed in detail in the *UXI ICARUS – Focal Plane Array Interface Document*, so this document will not repeat the information contained there. *Note:* the use of the HST\_DIV\_CLK monitor is not needed here as the FPGA controls the timing of each integration and interframe time. Manual timing can be set independently for the two hemispheres. Refer to the Jupyter notebook *nsCameraTutorial.ipynb* located in the nsCamera software package docs directory for a demonstration of how to use manual shutters.



Figure 4. Manual Shutter Timing, Icarus Sensor (A and B sides are here set to the same timing)

Some things to note when using the Manual Shutter Control function of the Icarus sensor:

- 1. To configure the FPGA and sensor for Manual Shutter control, write a '1' to the **MANSHUT\_MODE** subregister.
- 2. The **WX\_INTEGRATION** and **WY\_INTERFRAME** ( $X \in \{0,1,2,3\}$ ,  $Y \in \{0,1,2\}$ ) registers must be programmed to define the timing in 25 ns steps.
- 3. After the registers are set up properly, the timing sequence in Figure 4 is initiated when the FPGA detects the rising edge of the Fine Trigger.





### 13.7 Power Save Mode

Power Save Mode is enabled by asserting bit 3 of the **CTRL\_REG** register. When asserted, sensor power saving is achieved by controlling the Icarus sensor's *hst\_osc\_bias\_en* signal. During power save mode, *hst\_osc\_bias\_en* is asserted when the coarse trigger is detected; it is de-asserted once the sensor readout is complete. Power consumed by the sensor's digital power supply is reduced by 3.3% with Power Save Mode enabled; the sensor's analog power requirements are reduced by 0.6%. The average current and power consumption are listed in Table 16.

|                      | Sensor +       | 3.3 VDD       | Sensor +3.3 VA |               |  |
|----------------------|----------------|---------------|----------------|---------------|--|
|                      | Power Save OFF | Power Save ON | Power Save OFF | Power Save ON |  |
| Average Current (mA) | 37             | 35.7          | 5.02           | 5.05          |  |
| Average Power (mW)   | 122            | 118           | 16.56          | 16.66         |  |

Table 16: Power Save Mode Results

### 14 RS422 USB Cable

The RS422 USB cable that has been tested for the camera board is the ACCESS I/O Products, Inc. USB-422-IND cable. The datasheet and drivers for this product can be accessed at https://accesio.com/?p=/usb/usb-232-422485-IND.html .

## 15 Software Support

The 'nsCamera' python package provides a software driver and user interface for operating the NSG camera. The software runs under Windows, MacOS and Linux. Python 3 is recommended; Python 2 is supported but deprecated.

The software is distributed as a compressed archive or is available as part of a complete pre-packaged python environment. Instructions for installation and use are given in the project's README.md file. The software is also available as a MicroManager plugin for use in imageJ.

A Jupyter notebook tutorial *nsCameraTutorial.ipynb* that introduces the software and demonstrates many of the board's features can be found in the *nsCamera/docs* directory. This directory also contains detailed code documentation and the test script *testSuite.py*, which performs an extensive sequence of tests to verify the proper operation of the hardware and software.

### 16 FIM-U References

LLNL's Enterprise Lifecycle Management – Unclassified (ELM-U) stores various references for the LLNL V1.0 board. Specifically, the revisions of the board are documented. The references include schematic, Gerber files, CAD drawings, etc. The ELM number (specifically the assembly number) for the board is 1000189775.







## 17 Change note history

See the first page of this document for more recent changes.

| Rev. | Date     | Section<br>Edits         | Eng. | Description of Change                                                                                                                                                                                                                                                                   |
|------|----------|--------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0  | 10/19/17 | N/A                      | ССМ  | Initial Release                                                                                                                                                                                                                                                                         |
| 1.01 | 12/27/17 | 13                       | CCM  | Fix dual_edge_Trig_en description – s.b. in trigger_ctl register                                                                                                                                                                                                                        |
| 1.02 | 1/22/18  | 13                       | CCM  | Fix typos in register table entries for register 0x99 ADC5_DATA_4.                                                                                                                                                                                                                      |
| 1.03 | 2/8/18   | 14.7                     | CCM  | Add table listing all FPGA resets for rad hard version                                                                                                                                                                                                                                  |
| 1.04 | 3/7/18   | 11-14,<br>16             | JMH  | Divergence of Icarus & Daedalus ICD versions Change to 12-bit register addresses Removed specifications for Sandia Rev C board                                                                                                                                                          |
| 1.05 | 3/20/18  | 13                       | JMH  | Removed obsolete registers                                                                                                                                                                                                                                                              |
| 1.06 | 4/10/18  | -                        | JMH  | Divergence of LLNLv1 and LLNLv4 versions Expanded FPGA_NUM definitions                                                                                                                                                                                                                  |
| 1.07 | 6/26/18  | -                        | JMH  | Spinoff of sensor-specific implementation into separate document.  Added subregister names to register list                                                                                                                                                                             |
| 1.08 | 7/31/18  | All                      | JMH  | Register and subregister definitions added Reintegration of sensor-specific details                                                                                                                                                                                                     |
| 1.09 | 9/26/18  | -                        | JMH  | Miscellaneous; synced to nsCamera software release 2.0.5                                                                                                                                                                                                                                |
| 1.10 | 12/5/18  |                          | JMH  | Enter details for all RSLScan in and out registers, and BGTRIMA/B registers. Enter updated description for the FPGA_REV register                                                                                                                                                        |
| 1.11 | 6/4/19   | 13                       | JMH  | Added SW_TRIG_EN, Daedalus mode details                                                                                                                                                                                                                                                 |
| 1.12 | 6/24/19  | All                      | BTF  | Edited the description of each pot for ICARUS and DAEDALUS configured boards. Pointed the register map descriptions to the appropriate section to describe the pots. Minor edits to all sections. Synced to nsCamera 2.0.8                                                              |
| 1.13 | 9/30/19  | 5, 7,<br>13.1            | BTF  | More detailed information on the Daedalus-configured board for pot values. Added TRIGGER_CTL register info for previous firmware version vs. after of 9/19.                                                                                                                             |
| 1.14 | 10/25/19 | 7                        | BTF  | VAB on v1 board Daedalus was not listed on the Pot voltage control.  VAB cannot be monitored, but can be set.                                                                                                                                                                           |
| 1.15 | 11/13/19 | 6, 7,<br>11.1,<br>13, 16 | BTF  | Resolved comments made by Jeremy. Updated default pot voltages in Register Map section. Need input on if we want to describe pot voltage values in the register map as it is redundant from Section 6 and 7. Need update on CTL_REG in Section 13 for reverse readoff and slow readoff. |
| 1.16 | 1/3/20   | 11                       | BTF  | Resolved definitions of ADC monitor of pots between Icarus and Daedalus. Changed FPA_FRAME_ORDER_SEL to FRAME_ORDER_SEL register.                                                                                                                                                       |
| 1.17 | 2/14/20  | 5, 7, 11                 | BTF  | Converted SENSOR_VOLT_STAT and SENSOR_VOLT_CTL registers as Icarus firmware specific registers. Removed September 2019 TRIGGER_CTL setting for the trigger modes.                                                                                                                       |
| 1.18 | 3/3/20   | 6                        | JMH  | Trigger controls finalized. Synced to nsCamera 2.0.9                                                                                                                                                                                                                                    |
| 1.19 | 5/4/20   | 3, 6,<br>11, 14          | BTF  | Attempted to resolve comments: resolved figure with Daedalus timing block, explained more details on dual edge trigger, described details                                                                                                                                               |







|      |            |                                    |     | for Daedalus registers, and added what features work for Daedalus and what features do not. Synchronized to nsCamera 2.1                                                                                                                                                                                                                                                                                                         |
|------|------------|------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.20 | 5/26/20    | 5,7,11<br>13,14                    | JMH | Sensor-specific details moved to sensor sections and restructured. Removed unused quad_enable registers. Updated Daedalus POT & monitor assignments                                                                                                                                                                                                                                                                              |
| 1.21 | 8/13/2020  | 6.3,<br>12.7,<br>13, 14            | BTF | Will test Section 6.3 comment as well as Section 11 register map in lab. Revised Section 12.7 file names. Revised Sections 13 and 14 for Tables 17 and 19 by removing parenthesis and associated number of ADC5 monitor sub channel.                                                                                                                                                                                             |
| 1.22 | 9/22/2020  | 2, 11.1,<br>14                     | BTF | Added the sensor readoff time for Daedalus. Fixed up register map with respect to Daedalus implementation. Updated Daedalus Implementation section.                                                                                                                                                                                                                                                                              |
| 2.0  | 10/16/2020 | 6.3,<br>11.1,<br>13, 14,<br>15, 17 | BTF | Added Section 14 mentioning the RS422 USB driver location that is used and primarily tested with the hardware. Added Section 16 to discuss ELM-U references to the board. Updated temperature data in STAT_REG as 12-bits instead of 11 bits and confirmed Daedalus RSL left and right signals as always '0' in Section 11.1 . Updated Dual Edge Trigger in Section 6.3. Moved Power Save Mode Section to Icarus Implementation. |

## 18 References

- Sandia National Laboratories, et al. "UXI ICARUS Focal Plane Array Interface Document." Revision 6, 8/23/16
- 2) Claus, L., et al. "An overview of the Ultra-Fast X-ray Imager (UXI) program at Sandia Labs." Proceedings Volume 9591, Target Diagnostics Physics and Engineering for Inertial Confinement Fusion IV; 95910P (2015); doi: 10.1117/12.2188336
- 3) Claus, Liam D., et al. "The Ultrafast X-ray Imager (UXI) Program." No. SAND2016-7045PE. Sandia National Laboratories (SNL-NM), Albuquerque, NM (United States), 2016.
- 4) Claus, L., et al. "Design and characterization of an improved 2 ns multi-frame imager for the ultra-fast x-ray imager (UXI) program at Sandia National Laboratories." Proc. SPIE 10390, Target Diagnostics Physics and Engineering for Inertial Confinement Fusion VI, 103900A (24 August 2017); doi: 10.1117/12.2275293
- 5) Sanchez, Marcos. "Icarus HDD V2." Version 8. Advanced Hybrid CMOS Systems (AHS), Albuquerque, NM (United States), February 22, 2024.
- 6) Sanchez, Marcos. "UXI\_Daedalus\_HDD." Version 9. Sandia National Laboratories (SNL-NM), Albuquerque, NM (United States), July 15, 2019.